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.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.2.tar.gz (248.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.2-cp36-cp36m-manylinux1_x86_64.whl (548.6 kB view details)

Uploaded CPython 3.6m

ruamel.yaml-0.15.2-cp35-cp35m-manylinux1_x86_64.whl (548.5 kB view details)

Uploaded CPython 3.5m

ruamel.yaml-0.15.2-cp34-cp34m-manylinux1_x86_64.whl (555.0 kB view details)

Uploaded CPython 3.4m

ruamel.yaml-0.15.2-cp33-cp33m-manylinux1_x86_64.whl (529.1 kB view details)

Uploaded CPython 3.3m

ruamel.yaml-0.15.2-cp27-cp27mu-manylinux1_x86_64.whl (525.1 kB view details)

Uploaded CPython 2.7mu

ruamel.yaml-0.15.2-cp27-cp27m-manylinux1_x86_64.whl (525.1 kB view details)

Uploaded CPython 2.7m

File details

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

File metadata

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

File hashes

Hashes for ruamel.yaml-0.15.2.tar.gz
Algorithm Hash digest
SHA256 fca6974460113c6c191d806d0e1f326c9b811e74c833d9c040965c0203294185
MD5 c4554cae6ff010636a164de32a48f71d
BLAKE2b-256 2072d0fec16edfed7fc7980fd3dc4c9a4716df58aca93986c4a00a9decd4a950

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for ruamel.yaml-0.15.2-cp36-cp36m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 47119ec5d0fd4c894fe08e5317f36b6628f56d8f0e55922e7a014997c944df6d
MD5 737d36820dabb8b19619cea7db424fca
BLAKE2b-256 561cf87cbe54575af14dbd5933621611f70e1ce9adbaa56a86e90628dc5a4c60

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for ruamel.yaml-0.15.2-cp35-cp35m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 4f90858186c6cf90694f5d54f9580b54cb2388723629f39aa6c76268e51ea1c0
MD5 6379021120a639a545acdf8824e09478
BLAKE2b-256 b0b5f30beefa98b205cbfdd59e37afe537f26ac66eb7316784abd018a696d7b1

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for ruamel.yaml-0.15.2-cp34-cp34m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 092fc823847f348e18dcd894e20d723c0d7637c8e1b9edde657708bc4d1bc85f
MD5 1ef38776a28067a3eb9356b92078ae6c
BLAKE2b-256 cec0eb79e2f425faa2979f9aeca2e3a8f28c5b2718b41f5688d049041eb2ae68

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for ruamel.yaml-0.15.2-cp33-cp33m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 dbfa092ddd5520a965447c69bc34f270ebb79531f0592ed85df53446f0be908f
MD5 fc056f752da2ba0b9149d1cf194f5b48
BLAKE2b-256 87cb38ac280e41846e0acc2a4b37b35c53b3db0cb3b98954a4c8596e6e01fce0

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for ruamel.yaml-0.15.2-cp27-cp27mu-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 3e1af09ed3e70af3735d1f14dec4e0279930de9958691ac0e215e68531e5bffd
MD5 ddb6438a0c3a645b016aa3c5ec9dee48
BLAKE2b-256 f3b27b2cf141a7b8af527aec0d34c1b47495ed7caa5e0a0ec19ba531605375e0

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for ruamel.yaml-0.15.2-cp27-cp27m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 ad138d0e753db11510f3d1fd905736e27c8e4b70c06a2a92832f274598dcb1c2
MD5 4fb2cf5368a9755e141f5ff6c1b1ef67
BLAKE2b-256 15d399048bc32a527f1d15c8606e19933c4d75f0b63214aaab49a52bdf4f6480

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