Skip to main content

Modern high-performance serialization utilities for Python

Project description

srsly: Modern high-performance serialization utilities for Python

This package bundles some of the best Python serialization libraries into one standalone package, with a high-level API that makes it easy to write code that's correct across platforms and Pythons. This allows us to provide all the serialization utilities we need in a single binary wheel. Currently supports JSON, JSONL, MessagePack, Pickle and YAML.

Azure Pipelines PyPi conda GitHub Python wheels

Motivation

Serialization is hard, especially across Python versions and multiple platforms. After dealing with many subtle bugs over the years (encodings, locales, large files) our libraries like spaCy and Prodigy have steadily grown a number of utility functions to wrap the multiple serialization formats we need to support (especially json, msgpack and pickle). These wrapping functions ended up duplicated across our codebases, so we wanted to put them in one place.

At the same time, we noticed that having a lot of small dependencies was making maintenance harder, and making installation slower. To solve this, we've made srsly standalone, by including the component packages directly within it. This way we can provide all the serialization utilities we need in a single binary wheel.

srsly currently includes forks of the following packages:

Installation

⚠️ Note that v2.x is only compatible with Python 3.6+. For 2.7+ compatibility, use v1.x.

srsly can be installed from pip:

pip install srsly

Or from conda via conda-forge:

conda install -c conda-forge srsly

Alternatively, you can also compile the library from source. You'll need to make sure that you have a development environment consisting of a Python distribution including header files, a compiler (XCode command-line tools on macOS / OS X or Visual C++ build tools on Windows), pip, virtualenv and git installed.

pip install -r requirements.txt  # install development dependencies
python setup.py build_ext --inplace  # compile the library

API

JSON

📦 The underlying module is exposed via srsly.ujson. However, we normally interact with it via the utility functions only.

function srsly.json_dumps

Serialize an object to a JSON string. Falls back to json if sort_keys=True is used (until it's fixed in ujson).

data = {"foo": "bar", "baz": 123}
json_string = srsly.json_dumps(data)
Argument Type Description
data - The JSON-serializable data to output.
indent int Number of spaces used to indent JSON. Defaults to 0.
sort_keys bool Sort dictionary keys. Defaults to False.
RETURNS str The serialized string.

function srsly.json_loads

Deserialize unicode or bytes to a Python object.

data = '{"foo": "bar", "baz": 123}'
obj = srsly.json_loads(data)
Argument Type Description
data str / bytes The data to deserialize.
RETURNS - The deserialized Python object.

function srsly.write_json

Create a JSON file and dump contents or write to standard output.

data = {"foo": "bar", "baz": 123}
srsly.write_json("/path/to/file.json", data)
Argument Type Description
location str / Path The file path or "-" to write to stdout.
data - The JSON-serializable data to output.
indent int Number of spaces used to indent JSON. Defaults to 2.

function srsly.read_json

Load JSON from a file or standard input.

data = srsly.read_json("/path/to/file.json")
Argument Type Description
location str / Path The file path or "-" to read from stdin.
RETURNS dict / list The loaded JSON content.

function srsly.write_gzip_json

Create a gzipped JSON file and dump contents.

data = {"foo": "bar", "baz": 123}
srsly.write_gzip_json("/path/to/file.json.gz", data)
Argument Type Description
location str / Path The file path.
data - The JSON-serializable data to output.
indent int Number of spaces used to indent JSON. Defaults to 2.

function srsly.read_gzip_json

Load gzipped JSON from a file.

data = srsly.read_gzip_json("/path/to/file.json.gz")
Argument Type Description
location str / Path The file path.
RETURNS dict / list The loaded JSON content.

function srsly.write_jsonl

Create a JSONL file (newline-delimited JSON) and dump contents line by line, or write to standard output.

data = [{"foo": "bar"}, {"baz": 123}]
srsly.write_jsonl("/path/to/file.jsonl", data)
Argument Type Description
location str / Path The file path or "-" to write to stdout.
lines iterable The JSON-serializable lines.
append bool Append to an existing file. Will open it in "a" mode and insert a newline before writing lines. Defaults to False.
append_new_line bool Defines whether a new line should first be written when appending to an existing file. Defaults to True.

function srsly.read_jsonl

Read a JSONL file (newline-delimited JSON) or from JSONL data from standard input and yield contents line by line. Blank lines will always be skipped.

data = srsly.read_jsonl("/path/to/file.jsonl")
Argument Type Description
location str / Path The file path or "-" to read from stdin.
skip bool Skip broken lines and don't raise ValueError. Defaults to False.
YIELDS - The loaded JSON contents of each line.

function srsly.is_json_serializable

Check if a Python object is JSON-serializable.

assert srsly.is_json_serializable({"hello": "world"}) is True
assert srsly.is_json_serializable(lambda x: x) is False
Argument Type Description
obj - The object to check.
RETURNS bool Whether the object is JSON-serializable.

msgpack

📦 The underlying module is exposed via srsly.msgpack. However, we normally interact with it via the utility functions only.

function srsly.msgpack_dumps

Serialize an object to a msgpack byte string.

data = {"foo": "bar", "baz": 123}
msg = srsly.msgpack_dumps(data)
Argument Type Description
data - The data to serialize.
RETURNS bytes The serialized bytes.

function srsly.msgpack_loads

Deserialize msgpack bytes to a Python object.

msg = b"\x82\xa3foo\xa3bar\xa3baz{"
data = srsly.msgpack_loads(msg)
Argument Type Description
data bytes The data to deserialize.
use_list bool Don't use tuples instead of lists. Can make deserialization slower. Defaults to True.
RETURNS - The deserialized Python object.

function srsly.write_msgpack

Create a msgpack file and dump contents.

data = {"foo": "bar", "baz": 123}
srsly.write_msgpack("/path/to/file.msg", data)
Argument Type Description
location str / Path The file path.
data - The data to serialize.

function srsly.read_msgpack

Load a msgpack file.

data = srsly.read_msgpack("/path/to/file.msg")
Argument Type Description
location str / Path The file path.
use_list bool Don't use tuples instead of lists. Can make deserialization slower. Defaults to True.
RETURNS - The loaded and deserialized content.

pickle

📦 The underlying module is exposed via srsly.cloudpickle. However, we normally interact with it via the utility functions only.

function srsly.pickle_dumps

Serialize a Python object with pickle.

data = {"foo": "bar", "baz": 123}
pickled_data = srsly.pickle_dumps(data)
Argument Type Description
data - The object to serialize.
protocol int Protocol to use. -1 for highest. Defaults to None.
RETURNS bytes The serialized object.

function srsly.pickle_loads

Deserialize bytes with pickle.

pickled_data = b"\x80\x04\x95\x19\x00\x00\x00\x00\x00\x00\x00}\x94(\x8c\x03foo\x94\x8c\x03bar\x94\x8c\x03baz\x94K{u."
data = srsly.pickle_loads(pickled_data)
Argument Type Description
data bytes The data to deserialize.
RETURNS - The deserialized Python object.

YAML

📦 The underlying module is exposed via srsly.ruamel_yaml. However, we normally interact with it via the utility functions only.

function srsly.yaml_dumps

Serialize an object to a YAML string. See the ruamel.yaml docs for details on the indentation format.

data = {"foo": "bar", "baz": 123}
yaml_string = srsly.yaml_dumps(data)
Argument Type Description
data - The JSON-serializable data to output.
indent_mapping int Mapping indentation. Defaults to 2.
indent_sequence int Sequence indentation. Defaults to 4.
indent_offset int Indentation offset. Defaults to 2.
sort_keys bool Sort dictionary keys. Defaults to False.
RETURNS str The serialized string.

function srsly.yaml_loads

Deserialize unicode or a file object to a Python object.

data = 'foo: bar\nbaz: 123'
obj = srsly.yaml_loads(data)
Argument Type Description
data str / file The data to deserialize.
RETURNS - The deserialized Python object.

function srsly.write_yaml

Create a YAML file and dump contents or write to standard output.

data = {"foo": "bar", "baz": 123}
srsly.write_yaml("/path/to/file.yml", data)
Argument Type Description
location str / Path The file path or "-" to write to stdout.
data - The JSON-serializable data to output.
indent_mapping int Mapping indentation. Defaults to 2.
indent_sequence int Sequence indentation. Defaults to 4.
indent_offset int Indentation offset. Defaults to 2.
sort_keys bool Sort dictionary keys. Defaults to False.

function srsly.read_yaml

Load YAML from a file or standard input.

data = srsly.read_yaml("/path/to/file.yml")
Argument Type Description
location str / Path The file path or "-" to read from stdin.
RETURNS dict / list The loaded YAML content.

function srsly.is_yaml_serializable

Check if a Python object is YAML-serializable.

assert srsly.is_yaml_serializable({"hello": "world"}) is True
assert srsly.is_yaml_serializable(lambda x: x) is False
Argument Type Description
obj - The object to check.
RETURNS bool Whether the object is YAML-serializable.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

srsly-2.2.0.tar.gz (314.4 kB view details)

Uploaded Source

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

srsly-2.2.0-cp38-cp38-win_amd64.whl (452.0 kB view details)

Uploaded CPython 3.8Windows x86-64

srsly-2.2.0-cp38-cp38-manylinux1_x86_64.whl (453.4 kB view details)

Uploaded CPython 3.8

srsly-2.2.0-cp38-cp38-macosx_10_9_x86_64.whl (450.5 kB view details)

Uploaded CPython 3.8macOS 10.9+ x86-64

srsly-2.2.0-cp37-cp37m-win_amd64.whl (450.2 kB view details)

Uploaded CPython 3.7mWindows x86-64

srsly-2.2.0-cp37-cp37m-manylinux1_x86_64.whl (453.6 kB view details)

Uploaded CPython 3.7m

srsly-2.2.0-cp37-cp37m-macosx_10_9_x86_64.whl (449.3 kB view details)

Uploaded CPython 3.7mmacOS 10.9+ x86-64

srsly-2.2.0-cp36-cp36m-win_amd64.whl (450.3 kB view details)

Uploaded CPython 3.6mWindows x86-64

srsly-2.2.0-cp36-cp36m-manylinux1_x86_64.whl (453.5 kB view details)

Uploaded CPython 3.6m

srsly-2.2.0-cp36-cp36m-macosx_10_9_x86_64.whl (451.6 kB view details)

Uploaded CPython 3.6mmacOS 10.9+ x86-64

File details

Details for the file srsly-2.2.0.tar.gz.

File metadata

  • Download URL: srsly-2.2.0.tar.gz
  • Upload date:
  • Size: 314.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.47.0 CPython/3.7.7

File hashes

Hashes for srsly-2.2.0.tar.gz
Algorithm Hash digest
SHA256 a4a8196590e2623d668ae49349dd7d33f31f5ae56ba8c1a9f4587301f73744c0
MD5 94fcfbef0898a617eb4f98aa50b66eca
BLAKE2b-256 8bfab12b47b714e6eb733d93c96ccb41bb6a742b38c0df101f534d8e0eb79b57

See more details on using hashes here.

File details

Details for the file srsly-2.2.0-cp38-cp38-win_amd64.whl.

File metadata

  • Download URL: srsly-2.2.0-cp38-cp38-win_amd64.whl
  • Upload date:
  • Size: 452.0 kB
  • Tags: CPython 3.8, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.47.0 CPython/3.7.7

File hashes

Hashes for srsly-2.2.0-cp38-cp38-win_amd64.whl
Algorithm Hash digest
SHA256 08133e081fa89a6bc73869eabd59b20c4f502a1aae02c7892014f863fcaa6d90
MD5 0805d8898da08ab1ce39a1983f6dbdd7
BLAKE2b-256 79fab69d17869b27281bc0c1168f34bba442aac7a24b99b0fe3a8b19d3ff06dc

See more details on using hashes here.

File details

Details for the file srsly-2.2.0-cp38-cp38-manylinux1_x86_64.whl.

File metadata

  • Download URL: srsly-2.2.0-cp38-cp38-manylinux1_x86_64.whl
  • Upload date:
  • Size: 453.4 kB
  • Tags: CPython 3.8
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.47.0 CPython/3.7.7

File hashes

Hashes for srsly-2.2.0-cp38-cp38-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 cd851e7bb597ea9d999c1ff936ae912928220239bb33e745edd61e084be3906f
MD5 fe5e2b7f587fe2c4c8c6dfde950d995e
BLAKE2b-256 4f2e72fd1ffa7f3a0caf13dc953be9f86464bc4fc9889225219bfb8fe4f63020

See more details on using hashes here.

File details

Details for the file srsly-2.2.0-cp38-cp38-macosx_10_9_x86_64.whl.

File metadata

  • Download URL: srsly-2.2.0-cp38-cp38-macosx_10_9_x86_64.whl
  • Upload date:
  • Size: 450.5 kB
  • Tags: CPython 3.8, macOS 10.9+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.47.0 CPython/3.7.7

File hashes

Hashes for srsly-2.2.0-cp38-cp38-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 1401539289f30ffff7345d5276de1ce65627d6a86b4670072574c9416fd9ab29
MD5 e7c8ba6d1fa2bb5993a947ddc507da90
BLAKE2b-256 9b1f7c774ef6f254650702ec60137759720687890af082665361ce79eea0f9f0

See more details on using hashes here.

File details

Details for the file srsly-2.2.0-cp37-cp37m-win_amd64.whl.

File metadata

  • Download URL: srsly-2.2.0-cp37-cp37m-win_amd64.whl
  • Upload date:
  • Size: 450.2 kB
  • Tags: CPython 3.7m, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.47.0 CPython/3.7.7

File hashes

Hashes for srsly-2.2.0-cp37-cp37m-win_amd64.whl
Algorithm Hash digest
SHA256 9c282b93fd5fc69fdc0a596534659d7134504163744838603efbef847df4dfb4
MD5 684ef2065761320bfe79aed6d9df0391
BLAKE2b-256 f3fd35028adff49d9ab0b066d861590d6b443fd6132e59c039f58979202a27c0

See more details on using hashes here.

File details

Details for the file srsly-2.2.0-cp37-cp37m-manylinux1_x86_64.whl.

File metadata

  • Download URL: srsly-2.2.0-cp37-cp37m-manylinux1_x86_64.whl
  • Upload date:
  • Size: 453.6 kB
  • Tags: CPython 3.7m
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.47.0 CPython/3.7.7

File hashes

Hashes for srsly-2.2.0-cp37-cp37m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 428312bf223da711f19b69f5c09096546e35a4d45c50344fe704813d0aca4d91
MD5 85ea7900feba3186c2cc5b5bbfe65491
BLAKE2b-256 ef3ebcadddb03c2180d4cecc6bacec796f14f99f50bfe9bd9616bf62cff509c6

See more details on using hashes here.

File details

Details for the file srsly-2.2.0-cp37-cp37m-macosx_10_9_x86_64.whl.

File metadata

  • Download URL: srsly-2.2.0-cp37-cp37m-macosx_10_9_x86_64.whl
  • Upload date:
  • Size: 449.3 kB
  • Tags: CPython 3.7m, macOS 10.9+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.47.0 CPython/3.7.7

File hashes

Hashes for srsly-2.2.0-cp37-cp37m-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 0a824690e72b816156da44643591b854b9243fb7843601909ae42d3b47c07020
MD5 7d4e1477adb864d188814a8b4b80a12a
BLAKE2b-256 b50d16a2fdc27fc0be33a6f0437f84a481a742e0bd0623f544081d09d5f2c07c

See more details on using hashes here.

File details

Details for the file srsly-2.2.0-cp36-cp36m-win_amd64.whl.

File metadata

  • Download URL: srsly-2.2.0-cp36-cp36m-win_amd64.whl
  • Upload date:
  • Size: 450.3 kB
  • Tags: CPython 3.6m, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.47.0 CPython/3.7.7

File hashes

Hashes for srsly-2.2.0-cp36-cp36m-win_amd64.whl
Algorithm Hash digest
SHA256 37fdec8f1fca02698d8512e4978f5dc5af742b658ae0696253eee28cc68f0cfe
MD5 90a64667d65cde9b25cf6c30b09dd421
BLAKE2b-256 b2567dbd6d5d8731ba6103f673450faf124f960e3e1cc2280aac4059abd48754

See more details on using hashes here.

File details

Details for the file srsly-2.2.0-cp36-cp36m-manylinux1_x86_64.whl.

File metadata

  • Download URL: srsly-2.2.0-cp36-cp36m-manylinux1_x86_64.whl
  • Upload date:
  • Size: 453.5 kB
  • Tags: CPython 3.6m
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.47.0 CPython/3.7.7

File hashes

Hashes for srsly-2.2.0-cp36-cp36m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 de2da5bba4549e6b181d4a665952fb84a8c2022bbcd5b7e00b72eb2aba5a79ff
MD5 d25b8db675096686eb3850b9770dd15b
BLAKE2b-256 8275c763cad25fc6418a91f808506e02fde8595e4df0af85fb68c4c6ea692c59

See more details on using hashes here.

File details

Details for the file srsly-2.2.0-cp36-cp36m-macosx_10_9_x86_64.whl.

File metadata

  • Download URL: srsly-2.2.0-cp36-cp36m-macosx_10_9_x86_64.whl
  • Upload date:
  • Size: 451.6 kB
  • Tags: CPython 3.6m, macOS 10.9+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.47.0 CPython/3.7.7

File hashes

Hashes for srsly-2.2.0-cp36-cp36m-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 1c166151c10dcbaff238e81b29736cffdcf210fd79df31d617f8a3a4e245a543
MD5 20b16bff33d265d932b2ed89f8f040f7
BLAKE2b-256 5d80ab1c8c10b15c5117d544c1b2420ceac429be3b64b251cac93a087fa4de35

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