GitXplorerGitXplorer
e

ryaml

public
27 stars
8 forks
5 issues

Commits

List of commits on branch main.
Verified
159fe2e2e92eed875a14cf112add8c244010b658

[pre-commit.ci] pre-commit autoupdate (#2)

ppre-commit-ci[bot] committed 3 years ago
Unverified
7feeab6cda5eaaea74d0eb7c6080a0e2d812cdd9

v0.4.0

eemmatyping committed 3 years ago
Unverified
5e85633da1d9c110a0fe401c16cca8b0b64fa4d6

Update dependencies

eemmatyping committed 3 years ago
Unverified
17a790e7a1da463e6c84efe48198a4b02bdbbd4d

Fix tests for PyPy

eemmatyping committed 3 years ago
Verified
4348f55ce3a09b408d21d8ce7647d22d5789d546

Merge pull request #1 from KokaKiwi/py-typed

eemmatyping committed 3 years ago
Verified
e64f5ce13c3ae6799415bf1801df5bc074a41f2a

Fix test runner config

KKokaKiwi committed 3 years ago

README

The README file for this repository.

ryaml

Quickly and safely parse yaml

What is ryaml?

ryaml is a Python library that wraps a Rust yaml parser, serde-yaml, to quickly and safely parse and dump yaml to and from Python objects.

It is not compatible with PyYAML, but has a similar design to the json module.

The hope is this will be used as a safe and fast yaml parser in lieu of PyYAML.

Installation

We ship binary wheels for Windows, Linux, and macOS, so as long as you are using Python 3.7+, you can run:

$ python -m pip install ryaml

Otherwise, you will need to build from source. To do so, first install Rust 1.41 stable.

Then you should be able to just

$ git clone https://github.com/ethanhs/ryaml
$ cd ryaml
$ python -m pip install .

Or if you want to build a wheel:

$ git clone https://github.com/ethanhs/ryaml
$ cd ryaml
$ python -m pip install maturin
$ maturin build --release --no-sdist
# OR if you want an abi3 wheel (compatible with Python 3.7+)
$ maturin build --release --no-sdist --cargo-extra-args="--features=abi3"

And a wheel will be created in target/wheels which you can install.

Usage

The API of ryaml is very similar to that of json in the standard library:

You can use ryaml.loads to read from a str:

import ryaml
obj = ryaml.loads('key: [10, "hi"]')
assert isinstance(obj, dict) # True
assert obj['key'][1] == "hi" # True

And ryaml.dumps to dump an object into a yaml file:

import ryaml
s = ryaml.dumps({ 'key' : None })
print(s)
# prints:
# ---
# key: ~

There are also ryaml.load and ryaml.load_all to read yaml document(s) from files:

import ryaml
obj = {'a': [{'b': 1}]}
with open('test.yaml', 'w') as w:
    ryaml.dump(w, obj)
with open('test.yaml', 'r') as r:
    assert ryaml.load(r) == obj
with open('multidoc.yaml', 'w') as multi:
    multi.write('''
---
a:
  key:
...
---
b:
  key:
    ''')
with open('multidoc.yaml', 'r') as multi:
    docs = ryaml.load_all(multi)
assert len(docs) == 2
assert docs[0]['a']['key'] is None

ryaml.load_all will, as seen above, load multiple documents from a single file.

Thanks

This project is standing on the shoulders of giants, and would not be possible without:

pyo3

serde-yaml

yaml-rust

pyo3-file

pythonize