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 https://bestpractices.coreinfrastructure.org/projects/1128/badge

ChangeLog

0.15.24 (2017-08-09):
  • added ScalarFloat which supports roundtripping of 23.1, 23.100, 42.00E+56, 0.0, -0.0 etc. while keeping the format. Underscores in mantissas are not preserved/supported (yet, is anybody using that?).

  • (finally) fixed longstanding issue 23 (reported by Antony Sottile), now handling comment between block mapping key and value correctly

  • warn on YAML 1.1 float input that is incorrect (triggered by invalid YAML provided by Cecil Curry)

  • allow setting of boolean representation (false, true) by using: yaml.boolean_representation = [u'False', u'True']

0.15.23 (2017-08-01):
  • fix for round_tripping integers on 2.7.X > sys.maxint (reported by ccatterina)

0.15.22 (2017-07-28):
  • fix for round_tripping singe excl. mark tags doubling (reported and fix by Jan Brezina)

0.15.21 (2017-07-25):
0.15.20 (2017-07-23):
  • wheels for windows including C extensions

0.15.19 (2017-07-13):
  • added object constructor for rt, decorator yaml_object to replace YAMLObject.

  • fix for problem using load_all with Path() instance

  • fix for load_all in combination with zero indent block style literal (pure=True only!)

0.15.18 (2017-07-04):
  • missing pure attribute on YAML useful for implementing !include tag constructor for including YAML files in a YAML file

  • some documentation improvements

  • trigger of doc build on new revision

0.15.17 (2017-07-03):
  • support for Unicode supplementary Plane output (input was already supported, triggered by this Stack Overflow Q&A)

0.15.16 (2017-07-01):
  • minor typing issues (reported and fix provided by Manvendra Singh

  • small doc improvements

0.15.15 (2017-06-27):
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):
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


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.24.tar.gz (256.8 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.24-cp36-cp36m-manylinux1_x86_64.whl (554.9 kB view details)

Uploaded CPython 3.6m

ruamel.yaml-0.15.24-cp35-cp35m-manylinux1_x86_64.whl (554.7 kB view details)

Uploaded CPython 3.5m

ruamel.yaml-0.15.24-cp34-cp34m-manylinux1_x86_64.whl (561.2 kB view details)

Uploaded CPython 3.4m

ruamel.yaml-0.15.24-cp33-cp33m-manylinux1_x86_64.whl (535.4 kB view details)

Uploaded CPython 3.3m

ruamel.yaml-0.15.24-cp27-cp27mu-manylinux1_x86_64.whl (531.2 kB view details)

Uploaded CPython 2.7mu

ruamel.yaml-0.15.24-cp27-cp27m-manylinux1_x86_64.whl (531.2 kB view details)

Uploaded CPython 2.7m

File details

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

File metadata

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

File hashes

Hashes for ruamel.yaml-0.15.24.tar.gz
Algorithm Hash digest
SHA256 358e59ebe8e05ce43efa1c2bbdc010e551ffe27799433a3bbb0f4dd066f57f43
MD5 2310bb342501ca751dea818f45109c24
BLAKE2b-256 91a13d467aa4244847570710e527402b3666b6bbc18b001249f001acb4aa832d

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for ruamel.yaml-0.15.24-cp36-cp36m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 88c65500094ddf5a7d3f6f0052b28dffd90bac72652d7d8231f6dcfa4825bced
MD5 14c00e12e7efe26b68aa43966acbc3e6
BLAKE2b-256 f681129dc6b7807fe169b9a13bb6aab255e0c7dd316b37b5eefe0b4831f70401

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for ruamel.yaml-0.15.24-cp35-cp35m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 cdf7d5c9bae992f908a488f955ec6f5303682f2b5f92d22ff7be1a82de38e7b6
MD5 57094036994f814dce3cfade23d3b1bb
BLAKE2b-256 19f42eabc614cff2b8b84dbdc14e090f932342e8b530f50c177e8b3bbf7cf6a2

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for ruamel.yaml-0.15.24-cp34-cp34m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 6c889dd4c2d90e4c532b5812420a3d88363235457632e1cced459038743cc2ec
MD5 f0a517092e684f6c8d7e3d7137698dec
BLAKE2b-256 a4106a4d2eb5c3af81e300f912c97b8c54bb911c5d00dd39451a68a547c34b1a

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for ruamel.yaml-0.15.24-cp33-cp33m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 775b9339836ee2f263e3123ca2a55a18452a558bfe73f78da6b33929f2ebf917
MD5 b876e35b34b1a6ac6a3a6c7cadc69b52
BLAKE2b-256 5ce429653ff22fb887a6ee0661c2e26a9d42dd74349b4cf0ea5ff6b6a791637a

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for ruamel.yaml-0.15.24-cp27-cp27mu-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 e04d8086e29180d3abd50fb1120f94a79dbde8e31f648f6cc323878e4ee0d048
MD5 1ecfeb0ad4491e0977ac710d9f51a447
BLAKE2b-256 e11f5ea1e107d2fdf31ae1e80de5696c353267966386301da4d4624a68d1b3ac

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for ruamel.yaml-0.15.24-cp27-cp27m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 a2cf3f24000c06137d45752ebed35bfed9afb6c300b49e0ac538c90034a4d10f
MD5 a7588b5123fb1d4035e6e3af42af8bc5
BLAKE2b-256 211ae7a265f0841b1abcaaa7c49fefbc4f74a77b6f2829949278494ee74b58c1

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