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.
ChangeLog
- 0.15.14 (2017-06-25):
fix for issue 133, in setup.py: change ModuleNotFoundError to ImportError (reported and fix by Asley Drake)
- 0.15.13 (2017-06-24):
suppress duplicate key warning on mappings with merge keys (reported by Cameron Sweeney)
- 0.15.12 (2017-06-24):
remove fatal dependency of setup.py on wheel package (reported by Cameron Sweeney)
- 0.15.11 (2017-06-24):
fix for issue 130, regression in nested merge keys (reported by David Fee)
- 0.15.10 (2017-06-23):
top level PreservedScalarString not indented if not explicitly asked to
remove Makefile (not very useful anyway)
some mypy additions
- 0.15.9 (2017-06-16):
fix for issue 127: tagged scalars were always quoted and seperated by a newline when in a block sequence (reported and largely fixed by Tommy Wang)
- 0.15.8 (2017-06-15):
allow plug-in install via install ruamel.yaml[jinja2]
- 0.15.7 (2017-06-14):
add plug-in mechanism for load/dump pre resp. post-processing
- 0.15.6 (2017-06-10):
a set() with duplicate elements now throws error in rt loading
support for toplevel column zero literal/folded scalar in explicit documents
- 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 now 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):
remove dependency on typing while still supporting mypy (http://stackoverflow.com/a/43516781/1307905)
fix unclarity in doc that stated 2.6 is supported (reported by feetdust)
- 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):
fix for 0o52 not being a string in YAML 1.1 (reported on StackOverflow Q&A 43138503 by Frank D)
- 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
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
Built Distributions
Hashes for ruamel.yaml-0.15.14-cp36-cp36m-manylinux1_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6b08068d690968b3ee5db1bc39d97679411e7424240c3302f04ad74f7df15898 |
|
MD5 | 551752fa0a6980d78b2b6eef46bdf4c6 |
|
BLAKE2b-256 | 9e184e173732d0481fed15e7c610610cf6db486ab0939a021a673ef516f5999f |
Hashes for ruamel.yaml-0.15.14-cp35-cp35m-manylinux1_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 11f933e9d457fe11fc35599df257b06f0396151a15d9d02e3850c3b54b2b760c |
|
MD5 | d57635592629c7ddb587b6a9778b7bbe |
|
BLAKE2b-256 | 73766ed893a65fb3b18c57d4badef6a3208f5910d2da25d80ff50c6fac1f7e4d |
Hashes for ruamel.yaml-0.15.14-cp34-cp34m-manylinux1_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 576ff0169c278d038ea7d4d76e566fb03fc11a86fe6d7aef8715839a5e6668b7 |
|
MD5 | b4e637228fdee92a824666e86582ec27 |
|
BLAKE2b-256 | c9f2eb7f9857d4ad51095a4199640cb08db0a91cf2accd9fe5f36e7608ab09f3 |
Hashes for ruamel.yaml-0.15.14-cp33-cp33m-manylinux1_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7cb7b4dc3916e0754bebff9a0facd4599fa0bac5299ef7f5cffd20d601544e79 |
|
MD5 | 9e93dfec1154904599b2431f419d25bf |
|
BLAKE2b-256 | 364f6a413337553416b16962a6bbbcebedba6f55528e05d9a3d4061ccf43be58 |
Hashes for ruamel.yaml-0.15.14-cp27-cp27mu-manylinux1_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | d784cb278fc0d01fa9819eed36e0307875cc7f6741671c2146ea40c93abcdacc |
|
MD5 | 5cc14ec62ad6c3dfd70fea76c2ed33f1 |
|
BLAKE2b-256 | 9c4749a70ccde950e13103171730a2ea7d2dfb60a203965081c6daacce89da1e |
Hashes for ruamel.yaml-0.15.14-cp27-cp27m-manylinux1_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 07d47cd2f843572650a36a9737324cbc52c82e302b3cef1f55b39202eb9a42fb |
|
MD5 | 5dd2790a9db46ec647582bdb52813851 |
|
BLAKE2b-256 | 96e75f0a40f7f6a0ab03bbb10ec4ce019b271b18166ec1a7494e9bb3966581c8 |