Skip to main content

ruamel.yaml is a YAML parser/emitter that supports roundtrip preservation of comments, seq/map flow style, and map key order

Project description

ruamel.yaml

ruamel.yaml is a YAML 1.2 loader/dumper package for Python.

Starting with version 0.15.0 the way YAML files are loaded and dumped is changing. See the API doc for details. Currently existing functionality will throw a warning before being changed/removed. For production systems you should pin the version being used with ``ruamel.yaml<=0.15``. There might be bug fixes in the 0.14 series, but new functionality is likely only to be available via the new API.

If your package uses ruamel.yaml and is not listed on PyPI, drop me an email, preferably with some infomormation on how you use the package (or a link to bitbucket/github) and I’ll keep you informed when the status of the API is stable enough to make the transition.

https://readthedocs.org/projects/yaml/badge/?version=stable

ChangeLog

0.15.5 (2017-06-08):
  • repeat load() on a single YAML() instance would fail.

0.15.4 (2017-06-08):
  • transform parameter on dump that expects a function taking a string and returning a string. This allows transformation of the output before it is written to stream. This forces creation of the complete output in memory!

  • some updates to the docs

0.15.3 (2017-06-07):
  • No longer try to compile C extensions on Windows. Compilation can be forced by setting the environment variable RUAMEL_FORCE_EXT_BUILD to some value before starting the pip install.

0.15.2 (2017-06-07):
  • update to conform to mypy 0.511: mypy –strict

0.15.1 (2017-06-07):
  • duplicate keys in mappings generate an error (in the old API this change generates a warning until 0.16)

  • dependecy on ruamel.ordereddict for 2.7 now via extras_require

0.15.0 (2017-06-04):
  • it is no allowed to pass in a pathlib.Path as “stream” parameter to all load/dump functions

  • passing in a non-supported object (e.g. a string) as “stream” will result in a much more meaningful YAMLStreamError.

  • assigning a normal string value to an existing CommentedMap key or CommentedSeq element will result in a value cast to the previous value’s type if possible.

  • added YAML class for new API

0.14.12 (2017-05-14):
  • fix for issue 119, deepcopy not returning subclasses (reported and PR by Constantine Evans <cevans@evanslabs.org>)

0.14.11 (2017-05-01):
  • fix for issue 103 allowing implicit documents after document end marker line (...) in YAML 1.2

0.14.10 (2017-04-26):
  • fix problem with emitting using cyaml

0.14.9 (2017-04-22):
0.14.8 (2017-04-19):
  • fix Text not available on 3.5.0 and 3.5.1, now proactively setting version guards on all files (reported by João Paulo Magalhães)

0.14.7 (2017-04-18):
  • round trip of integers (decimal, octal, hex, binary) now preserve leading zero(s) padding and underscores. Underscores are presumed to be at regular distances (i.e. 0o12_345_67 dumps back as 0o1_23_45_67 as the space from the last digit to the underscore before that is the determining factor).

0.14.6 (2017-04-14):
  • binary, octal and hex integers are now preserved by default. This was a known deficiency. Working on this was prompted by the issue report (112) from devnoname120, as well as the additional experience with .replace() on scalarstring classes.

  • fix issues 114: cannot install on Buildozer (reported by mixmastamyk). Setting env. var RUAMEL_NO_PIP_INSTALL_CHECK will suppress pip-check.

0.14.5 (2017-04-04):
  • fix issue 109: None not dumping correctly at top level (reported by Andrea Censi)

  • fix issue 110: .replace on Preserved/DoubleQuoted/SingleQuoted ScalarString would give back “normal” string (reported by sandres23)

0.14.4 (2017-03-31):
  • fix readme

0.14.3 (2017-03-31):
0.14.2 (2017-03-23):
  • fix for old default pip on Ubuntu 14.04 (reported by Sébastien Maccagnoni-Munch)

0.14.1 (2017-03-22):
  • fix Text not available on 3.5.0 and 3.5.1 (reported by Charles Bouchard-Légaré)

0.14.0 (2017-03-21):
  • updates for mypy –strict

  • preparation for moving away from inheritance in Loader and Dumper, calls from e.g. the Representer to the Serializer.serialize() are now done via the attribute .serializer.serialize(). Usage of .serialize() outside of Serializer will be deprecated soon

  • some extra tests on main.py functions

0.13.14 (2017-02-12):
  • fix for issue 97: clipped block scalar followed by empty lines and comment would result in two CommentTokens of which the first was dropped. (reported by Colm O’Connor)

0.13.13 (2017-01-28):
  • fix for issue 96: prevent insertion of extra empty line if indented mapping entries are separated by an empty line (reported by Derrick Sawyer)

0.13.11 (2017-01-23):
  • allow ‘:’ in flow style scalars if not followed by space. Also don’t quote such scalar as this is no longer necessary.

  • add python 3.6 manylinux wheel to PyPI

0.13.10 (2017-01-22):
  • fix for issue 93, insert spurious blank line before single line comment between indented sequence elements (reported by Alex)

0.13.9 (2017-01-18):
  • fix for issue 92, wrong import name reported by the-corinthian

0.13.8 (2017-01-18):
  • fix for issue 91, when a compiler is unavailable reported by Maximilian Hils

  • fix for deepcopy issue with TimeStamps not preserving ‘T’, reported on StackOverflow Q&A by Quuxplusone

0.13.7 (2016-12-27):
  • fix for issue 85, constructor.py importing unicode_literals caused mypy to fail on 2.7 (reported by Peter Amstutz)

0.13.6 (2016-12-27):
  • fix for issue 83, collections.OrderedDict not representable by SafeRepresenter (reported by Frazer McLean)

0.13.5 (2016-12-25):
  • fix for issue 84, deepcopy not properly working (reported by Peter Amstutz)

0.13.4 (2016-12-05):
  • another fix for issue 82, change to non-global resolver data broke implicit type specification

0.13.3 (2016-12-05):
  • fix for issue 82, deepcopy not working (reported by code monk)

0.13.2 (2016-11-28):
  • fix for comments after empty (null) values (reported by dsw2127 and cokelaer)

0.13.1 (2016-11-22):
  • optimisations on memory usage when loading YAML from large files (py3: -50%, py2: -85%)

0.13.0 (2016-11-20):
  • if load() or load_all() is called with only a single argument (stream or string) a UnsafeLoaderWarning will be issued once. If appropriate you can surpress this warning by filtering it. Explicitly supplying the Loader=ruamel.yaml.Loader argument, will also prevent it from being issued. You should however consider using safe_load(), safe_load_all() if your YAML input does not use tags.

  • allow adding comments before and after keys (based on StackOveflow Q&A by msinn)


For older changes see the file CHANGES

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ruamel.yaml-0.15.5.tar.gz (249.9 kB view details)

Uploaded Source

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

ruamel.yaml-0.15.5-cp36-cp36m-manylinux1_x86_64.whl (549.3 kB view details)

Uploaded CPython 3.6m

ruamel.yaml-0.15.5-cp35-cp35m-manylinux1_x86_64.whl (549.1 kB view details)

Uploaded CPython 3.5m

ruamel.yaml-0.15.5-cp34-cp34m-manylinux1_x86_64.whl (555.7 kB view details)

Uploaded CPython 3.4m

ruamel.yaml-0.15.5-cp33-cp33m-manylinux1_x86_64.whl (529.8 kB view details)

Uploaded CPython 3.3m

ruamel.yaml-0.15.5-cp27-cp27mu-manylinux1_x86_64.whl (525.7 kB view details)

Uploaded CPython 2.7mu

ruamel.yaml-0.15.5-cp27-cp27m-manylinux1_x86_64.whl (525.7 kB view details)

Uploaded CPython 2.7m

File details

Details for the file ruamel.yaml-0.15.5.tar.gz.

File metadata

  • Download URL: ruamel.yaml-0.15.5.tar.gz
  • Upload date:
  • Size: 249.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for ruamel.yaml-0.15.5.tar.gz
Algorithm Hash digest
SHA256 02646f51c8efa61a69150cb96859a3d45b2967fb3f50f6f245107e6e70134caf
MD5 04ec2d1fbf054836d2e28fdc5ee49f16
BLAKE2b-256 f24feaba16916cc25bc86d0599676374c4d1d3f4c49a724dd130877166f939ad

See more details on using hashes here.

File details

Details for the file ruamel.yaml-0.15.5-cp36-cp36m-manylinux1_x86_64.whl.

File metadata

File hashes

Hashes for ruamel.yaml-0.15.5-cp36-cp36m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 2dafa57cf8587051d829d6be31dc8d8079d088cfc5c366345675e23b0128f301
MD5 4663a7995f5e3033d7ab54c6480462c6
BLAKE2b-256 564bb7eaf0216db677028cb6de188b5ae958f6476ff4b3b9b13e25119b86620b

See more details on using hashes here.

File details

Details for the file ruamel.yaml-0.15.5-cp35-cp35m-manylinux1_x86_64.whl.

File metadata

File hashes

Hashes for ruamel.yaml-0.15.5-cp35-cp35m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 49fc7aeef85ecf944b6e1befb6f6fe29bcfb9fc58ca74cbd1e397a9194014038
MD5 7b6a36774652aa2eba74a0129d480325
BLAKE2b-256 bc0e0009f5e1394f3109fd246ac8dadc9ed2e41efc7d34b2371c15ec47d4949c

See more details on using hashes here.

File details

Details for the file ruamel.yaml-0.15.5-cp34-cp34m-manylinux1_x86_64.whl.

File metadata

File hashes

Hashes for ruamel.yaml-0.15.5-cp34-cp34m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 61ea62e8b713edd15ec9d6e10f720f28cd146786f3963fabb66e7b1fd51beae0
MD5 c6b2ced60a42a10570a1a143d53c91a1
BLAKE2b-256 92b4da759e73e9e8f9b9a4ec39c068dc3386a96421b56e5aab3044192454988c

See more details on using hashes here.

File details

Details for the file ruamel.yaml-0.15.5-cp33-cp33m-manylinux1_x86_64.whl.

File metadata

File hashes

Hashes for ruamel.yaml-0.15.5-cp33-cp33m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 6f07920cddef11f36b6b2e5ce876cb0b62d9682a91a6929b0794521ded63920c
MD5 72d33a02e93b7de8490f43cbe59adad3
BLAKE2b-256 2d6aa8d35b75882f690a91eb8794a9387db3de8bfb521b488f911a5ed2230b4b

See more details on using hashes here.

File details

Details for the file ruamel.yaml-0.15.5-cp27-cp27mu-manylinux1_x86_64.whl.

File metadata

File hashes

Hashes for ruamel.yaml-0.15.5-cp27-cp27mu-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 7406a78c823b6dfc04f1397d34410059bc164ca0ca5fc83962969903577a0a96
MD5 d7f2303e643b1546cfb754f035acaa27
BLAKE2b-256 8e021d409c10146f2e52a4122af75a0d8d96e4fab388f83ffcb4a6c35eb01b92

See more details on using hashes here.

File details

Details for the file ruamel.yaml-0.15.5-cp27-cp27m-manylinux1_x86_64.whl.

File metadata

File hashes

Hashes for ruamel.yaml-0.15.5-cp27-cp27m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 d287995d4dd609085a4dd41a5b3f5fdf2c1f7b7514fadbf88beece0e3404235f
MD5 c67d60a327c606e08e970a6dff76722c
BLAKE2b-256 0c3d22b163840d5df8d4fe2d48468d4b276983f0eb551ecfab0eca44ee335653

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page