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

Starting with 0.10.7 the package has been reorganised and the command line utility is in its own package ruamel.yaml.cmd (so installing ruamel.yaml doesn’t pull in possibly irrelevant modules only used in the command line utility)

ruamel.yaml is a YAML package for Python. It is a derivative of Kirill Simonov’s PyYAML 3.11 which supports YAML1.1

Major differences with PyYAML 3.11:

  • integrated Python 2 and 3 sources, running on Python 2.6, 2.7 (CPython, PyPy), 3.3 and 3.4.

  • round trip mode that includes comments (block mode, key ordering kept)

  • support for simple lists as mapping keys by transforming these to tuples

  • !!omap generates ordereddict (C) on Python 2, collections.OrderedDict on Python 3, and !!omap is generated for these types.

  • some YAML 1.2 enhancements (0o octal prefix, \/ escape)

  • pep8 compliance

  • tox and py.test based testing

  • Tests whether the C yaml library is installed as well as the header files. That library doesn’t generate CommentTokens, so it cannot be used to do round trip editing on comments. It can be used to speed up normal processing (so you don’t need to install ruamel.yaml and PyYaml). See the section Optional requirements.

  • Basic support for multiline strings with preserved newlines and chomping ( ‘|’, ‘|+’, ‘|-’ ). As this subclasses the string type the information is lost on reassignment. (This might be changed in the future so that the preservation/folding/chomping is part of the parent container, like comments).

  • RoundTrip preservation of flow style sequences ( ‘a: b, c, d’) (based on request and test by Anthony Sottile)

  • anchors names that are hand-crafted (not of the form``idNNN``) are preserved

  • merges in dictionaries are preserved

  • adding/replacing comments on block-style sequences and mappings with smart column positioning

  • collection objects (when read in via RoundTripParser) have an lc property that contains line and column info lc.line and lc.col. Individual positions for mappings and sequences can also be retrieved (lc.key('a'), lc.value('a') resp. lc.item(3))

  • preservation of whitelines after block scalars. Contributed by Sam Thursfield.

Round trip including comments

The major motivation for this fork is the round-trip capability for comments. The integration of the sources was just an initial step to make this easier.

adding/replacing comments

Starting with version 0.8, you can add/replace comments on block style collections (mappings/sequences resuting in Python dict/list). The basic for for this is:

from __future__ import print_function

import ruamel.yaml

inp = """\
abc:
  - a     # comment 1
xyz:
  a: 1    # comment 2
  b: 2
  c: 3
  d: 4
  e: 5
  f: 6 # comment 3
"""

data = ruamel.yaml.load(inp, ruamel.yaml.RoundTripLoader)
data['abc'].append('b')
data['abc'].yaml_add_eol_comment('comment 4', 1)  # takes column of comment 1
data['xyz'].yaml_add_eol_comment('comment 5', 'c')  # takes column of comment 2
data['xyz'].yaml_add_eol_comment('comment 6', 'e')  # takes column of comment 3
data['xyz'].yaml_add_eol_comment('comment 7', 'd', column=20)

print(ruamel.yaml.dump(data, Dumper=ruamel.yaml.RoundTripDumper), end='')

Resulting in:

abc:
- a       # comment 1
- b       # comment 4
xyz:
  a: 1    # comment 2
  b: 2
  c: 3    # comment 5
  d: 4              # comment 7
  e: 5 # comment 6
  f: 6 # comment 3

If the comment doesn’t start with ‘#’, this will be added. The key is the element index for list, the actual key for dictionaries. As can be seen from the example, the column to choose for a comment is derived from the previous, next or preceding comment column (picking the first one found).

Config file formats

There are only a few configuration file formats that are easily readable and editable: JSON, INI/ConfigParser, YAML (XML is to cluttered to be called easily readable).

Unfortunately JSON doesn’t support comments, and although there are some solutions with pre-processed filtering of comments, there are no libraries that support round trip updating of such commented files.

INI files support comments, and the excellent ConfigObj library by Foord and Larosa even supports round trip editing with comment preservation, nesting of sections and limited lists (within a value). Retrieval of particular value format is explicit (and extensible).

YAML has basic mapping and sequence structures as well as support for ordered mappings and sets. It supports scalars various types including dates and datetimes (missing in JSON). YAML has comments, but these are normally thrown away.

Block structured YAML is a clean and very human readable format. By extending the Python YAML parser to support round trip preservation of comments, it makes YAML a very good choice for configuration files that are human readable and editable while at the same time interpretable and modifiable by a program.

Extending

There are normally six files involved when extending the roundtrip capabilities: the reader, parser, composer and constructor to go from YAML to Python and the resolver, representer, serializer and emitter to go the other way.

Extending involves keeping extra data around for the next process step, eventuallly resulting in a different Python object (subclass or alternative), that should behave like the original, but on the way from Python to YAML generates the original (or at least something much closer).

Smartening

When you use round-tripping, then the complex data you get are already subclasses of the built-in types. So you can patch in extra methods or override existing ones. Some methods are already included and you can do:

yaml_str = """\
a:
- b:
  c: 42
- d:
    f: 196
  e:
    g: 3.14
"""


data = yaml.load(yaml_str, Loader=yaml.RoundTripLoader)

assert data.mlget(['a', 1, 'd', 'f'], list_ok=True) == 196

Examples

Basic round trip of parsing YAML to Python objects, modifying and generating YAML:

from __future__ import print_function

import ruamel.yaml

inp = """\
# example
name:
  # details
  family: Smith   # very common
  given: Alice    # one of the siblings
"""

code = ruamel.yaml.load(inp, ruamel.yaml.RoundTripLoader)
code['name']['given'] = 'Bob'

print(ruamel.yaml.dump(code, Dumper=ruamel.yaml.RoundTripDumper), end='')

Resulting in

# example
name:
  # details
  family: Smith   # very common
  given: Bob      # one of the siblings

YAML handcrafted anchors and references as well as key merging is preserved. The merged keys can transparently be accessed using [] and .get():

import ruamel.yaml

inp = """\
- &CENTER {x: 1, y: 2}
- &LEFT {x: 0, y: 2}
- &BIG {r: 10}
- &SMALL {r: 1}
# All the following maps are equal:
# Explicit keys
- x: 1
  y: 2
  r: 10
  label: center/big
# Merge one map
- <<: *CENTER
  r: 10
  label: center/big
# Merge multiple maps
- <<: [*CENTER, *BIG]
  label: center/big
# Override
- <<: [*BIG, *LEFT, *SMALL]
  x: 1
  label: center/big
"""

data = ruamel.yaml.load(inp, ruamel.yaml.RoundTripLoader)
assert data[7]['y'] == 2

Optional requirements

If you have the C yaml library and headers installed, as well as the header files for your Python executables then you can use the non-roundtrip but faster C loader and emitter.

On Debian systems you should use:

sudo apt-get install libyaml-dev python-dev python3-dev

you can leave out python3-dev if you don’t use python3

For CentOS (7) based systems you should do:

sudo yum install libyaml-devel python-devel

Testing

Testing is done using tox, which uses virtualenv and pytest.

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.10.16.tar.gz (235.1 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.10.16-cp34-none-win_amd64.whl (71.1 kB view details)

Uploaded CPython 3.4Windows x86-64

ruamel.yaml-0.10.16-cp34-none-win32.whl (71.1 kB view details)

Uploaded CPython 3.4Windows x86

ruamel.yaml-0.10.16-cp33-none-win_amd64.whl (71.1 kB view details)

Uploaded CPython 3.3Windows x86-64

ruamel.yaml-0.10.16-cp33-none-win32.whl (71.1 kB view details)

Uploaded CPython 3.3Windows x86

ruamel.yaml-0.10.16-cp27-none-win_amd64.whl (71.2 kB view details)

Uploaded CPython 2.7Windows x86-64

ruamel.yaml-0.10.16-cp27-none-win32.whl (71.2 kB view details)

Uploaded CPython 2.7Windows x86

ruamel.yaml-0.10.16-cp26-none-win_amd64.whl (71.2 kB view details)

Uploaded CPython 2.6Windows x86-64

ruamel.yaml-0.10.16-cp26-none-win32.whl (71.2 kB view details)

Uploaded CPython 2.6Windows x86

File details

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

File metadata

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

File hashes

Hashes for ruamel.yaml-0.10.16.tar.gz
Algorithm Hash digest
SHA256 25033ef916e051cb16c9c526fa7922222398845a084d1f6a8f2eac0850482efe
MD5 c83ccefbd6bbf106b0848c98eddcd4e5
BLAKE2b-256 15ffb01f32568dc336b0b6a94008186277eee1c9252af174da215cbc76ddbf5f

See more details on using hashes here.

File details

Details for the file ruamel.yaml-0.10.16-cp34-none-win_amd64.whl.

File metadata

File hashes

Hashes for ruamel.yaml-0.10.16-cp34-none-win_amd64.whl
Algorithm Hash digest
SHA256 6253eaa1de8893510347b3739bc97964b54bde2126349b2612d380239b368430
MD5 ff8baba59fb47b20e249f553bdfb68c0
BLAKE2b-256 570877016185864be05d4f8889e5b16e75678c5f630ea27d0f2890712e903004

See more details on using hashes here.

File details

Details for the file ruamel.yaml-0.10.16-cp34-none-win32.whl.

File metadata

File hashes

Hashes for ruamel.yaml-0.10.16-cp34-none-win32.whl
Algorithm Hash digest
SHA256 e245f7d4f5015792abb951d6a8de2d5d3b491fccdc5a3ea3427cd1e644fede40
MD5 50f4ba055fe86c9a7b6e1b16ef9e98d6
BLAKE2b-256 4a9e941619b5b003cf18326bcd8311c8f19fa265d128303a78b96932dd2a9870

See more details on using hashes here.

File details

Details for the file ruamel.yaml-0.10.16-cp33-none-win_amd64.whl.

File metadata

File hashes

Hashes for ruamel.yaml-0.10.16-cp33-none-win_amd64.whl
Algorithm Hash digest
SHA256 c9ace51ac3f69a5e88afef4790213a85a590912d29d4c733444aaa996023de5a
MD5 9e337df24d9c48bb1b4317eaffc2c5b8
BLAKE2b-256 5013a361685111be65709c6925dc7897c9bf45e4dec405a050e3f7a15ccae735

See more details on using hashes here.

File details

Details for the file ruamel.yaml-0.10.16-cp33-none-win32.whl.

File metadata

File hashes

Hashes for ruamel.yaml-0.10.16-cp33-none-win32.whl
Algorithm Hash digest
SHA256 7310b249b0ed9c1bf42fe1f1dea14e2578f65d7b312819cf2bafca415fc406cc
MD5 612e6e64addfca09245f772d5001aff4
BLAKE2b-256 625ecefcfb7d5b446f34e8801980a0b8f652d9b1910fc615ee02e458fa0efaf2

See more details on using hashes here.

File details

Details for the file ruamel.yaml-0.10.16-cp27-none-win_amd64.whl.

File metadata

File hashes

Hashes for ruamel.yaml-0.10.16-cp27-none-win_amd64.whl
Algorithm Hash digest
SHA256 638f622c1e51659024cce25f7f07b100252c70f30541ff117546f699555d2e1b
MD5 8a4ea3f19514e2384957f7346ad507ad
BLAKE2b-256 b3c9372bf37e72dc132716e7c817c746fa5c3b7c722697e5d96119a5f7f1895b

See more details on using hashes here.

File details

Details for the file ruamel.yaml-0.10.16-cp27-none-win32.whl.

File metadata

File hashes

Hashes for ruamel.yaml-0.10.16-cp27-none-win32.whl
Algorithm Hash digest
SHA256 a1f97fa145792ad26e44d1bd1e5dc24254125873fad57d41911c210e3a53eb90
MD5 fbe107747cfdf1ae354ff74142b4b8c9
BLAKE2b-256 207d38eb3ec7a36e9273a95b9a32d47a0f60d2822d803c25011918cedd7c4eb5

See more details on using hashes here.

File details

Details for the file ruamel.yaml-0.10.16-cp26-none-win_amd64.whl.

File metadata

File hashes

Hashes for ruamel.yaml-0.10.16-cp26-none-win_amd64.whl
Algorithm Hash digest
SHA256 a8b4436c9cf1ae380fc85bd8f14a85c240dc4aecf3efdae79b9282fc7f6b0523
MD5 2d87c19d6156bc94e03c999207030858
BLAKE2b-256 ea455706630f5fa37ad41cee1b4a0754580fb4643a70dd48a0bccd588f1c93a9

See more details on using hashes here.

File details

Details for the file ruamel.yaml-0.10.16-cp26-none-win32.whl.

File metadata

File hashes

Hashes for ruamel.yaml-0.10.16-cp26-none-win32.whl
Algorithm Hash digest
SHA256 a610da9129e46fff9e199d4877e0bd3b918daa4f532bfa29689d7b8011e68364
MD5 78e55108857bb2e4c6430514ec63623d
BLAKE2b-256 013946c608b316e87a51cc2118d16add52184ad5d403897e8e5d5e2b610eae6f

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