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. Before installing, make sure that your pip, setuptools and wheel are up to date.

pip install -U pip setuptools wheel
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
path 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
path 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
path 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
path 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
path 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
path 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
path 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
path 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
path 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
path 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.4.0.tar.gz (314.7 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.4.0-cp39-cp39-win_amd64.whl (451.1 kB view details)

Uploaded CPython 3.9Windows x86-64

srsly-2.4.0-cp39-cp39-manylinux2014_x86_64.whl (456.1 kB view details)

Uploaded CPython 3.9

srsly-2.4.0-cp39-cp39-macosx_10_9_x86_64.whl (451.9 kB view details)

Uploaded CPython 3.9macOS 10.9+ x86-64

srsly-2.4.0-cp38-cp38-win_amd64.whl (451.5 kB view details)

Uploaded CPython 3.8Windows x86-64

srsly-2.4.0-cp38-cp38-manylinux2014_x86_64.whl (458.3 kB view details)

Uploaded CPython 3.8

srsly-2.4.0-cp38-cp38-macosx_10_9_x86_64.whl (449.8 kB view details)

Uploaded CPython 3.8macOS 10.9+ x86-64

srsly-2.4.0-cp37-cp37m-win_amd64.whl (449.7 kB view details)

Uploaded CPython 3.7mWindows x86-64

srsly-2.4.0-cp37-cp37m-manylinux2014_x86_64.whl (456.2 kB view details)

Uploaded CPython 3.7m

srsly-2.4.0-cp37-cp37m-macosx_10_9_x86_64.whl (449.1 kB view details)

Uploaded CPython 3.7mmacOS 10.9+ x86-64

srsly-2.4.0-cp36-cp36m-win_amd64.whl (449.8 kB view details)

Uploaded CPython 3.6mWindows x86-64

srsly-2.4.0-cp36-cp36m-manylinux2014_x86_64.whl (456.2 kB view details)

Uploaded CPython 3.6m

srsly-2.4.0-cp36-cp36m-macosx_10_9_x86_64.whl (450.5 kB view details)

Uploaded CPython 3.6mmacOS 10.9+ x86-64

File details

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

File metadata

  • Download URL: srsly-2.4.0.tar.gz
  • Upload date:
  • Size: 314.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.56.0 CPython/3.7.9

File hashes

Hashes for srsly-2.4.0.tar.gz
Algorithm Hash digest
SHA256 e29730be53015970e4a59050e8e9f9be44d762108a617df56c9dfc981b515ab7
MD5 e74ba9df3f010694a172c64b91f2717b
BLAKE2b-256 fd63a9240c5e37b08e2fd9fc68a1ff30175f586d9d31a5f21529c4022ddcfc90

See more details on using hashes here.

File details

Details for the file srsly-2.4.0-cp39-cp39-win_amd64.whl.

File metadata

  • Download URL: srsly-2.4.0-cp39-cp39-win_amd64.whl
  • Upload date:
  • Size: 451.1 kB
  • Tags: CPython 3.9, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.56.0 CPython/3.7.9

File hashes

Hashes for srsly-2.4.0-cp39-cp39-win_amd64.whl
Algorithm Hash digest
SHA256 d49461cd7f4a6461fe850cf9cae24e1f415d64c73fdcbe8f45a1d9c53caf7d5d
MD5 984d7cc9235bef62d834b488686d3080
BLAKE2b-256 a03bd74aa4e0caf996053aad873eda6565524fb2ca32a269f6ac480bd3429fbb

See more details on using hashes here.

File details

Details for the file srsly-2.4.0-cp39-cp39-manylinux2014_x86_64.whl.

File metadata

  • Download URL: srsly-2.4.0-cp39-cp39-manylinux2014_x86_64.whl
  • Upload date:
  • Size: 456.1 kB
  • Tags: CPython 3.9
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.56.0 CPython/3.7.9

File hashes

Hashes for srsly-2.4.0-cp39-cp39-manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 e9da4e425e754ce3eafbc5aea73af4c60e5a700f454be720ee2349cf4f59a8dd
MD5 76b7a2d739bf32da6ece363333fbc74c
BLAKE2b-256 0e3614fbbd857ca9455654126d30c312ec93f999271785f11e7f54adc21b8fd0

See more details on using hashes here.

File details

Details for the file srsly-2.4.0-cp39-cp39-macosx_10_9_x86_64.whl.

File metadata

  • Download URL: srsly-2.4.0-cp39-cp39-macosx_10_9_x86_64.whl
  • Upload date:
  • Size: 451.9 kB
  • Tags: CPython 3.9, macOS 10.9+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.56.0 CPython/3.7.9

File hashes

Hashes for srsly-2.4.0-cp39-cp39-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 efa6977dc98069d5731e929d7c121bbe9764bcd39b44a232f600a81bcae0983e
MD5 ce5b1c175e2618b1dfc6ca79125cd70d
BLAKE2b-256 609bc20ac7883a3f53c210804c0401037d118145f7a7dc4f8d793527180ef84f

See more details on using hashes here.

File details

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

File metadata

  • Download URL: srsly-2.4.0-cp38-cp38-win_amd64.whl
  • Upload date:
  • Size: 451.5 kB
  • Tags: CPython 3.8, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.56.0 CPython/3.7.9

File hashes

Hashes for srsly-2.4.0-cp38-cp38-win_amd64.whl
Algorithm Hash digest
SHA256 c851d0644083a9607fbe343372d355a4ab6093348b119f5c870050911ffd7f41
MD5 fdc224fdb94b9974b1dfd4cd274a9bca
BLAKE2b-256 e6b5c35ed09e2dba1af460fda8b747277a191ee1e1e37019d6bbf896f4f30952

See more details on using hashes here.

File details

Details for the file srsly-2.4.0-cp38-cp38-manylinux2014_x86_64.whl.

File metadata

  • Download URL: srsly-2.4.0-cp38-cp38-manylinux2014_x86_64.whl
  • Upload date:
  • Size: 458.3 kB
  • Tags: CPython 3.8
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.56.0 CPython/3.7.9

File hashes

Hashes for srsly-2.4.0-cp38-cp38-manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 3fdaa7bbbfd930da28bbbfdddd31bf40e712bcd217f4534c8e56c47141bc8536
MD5 7fd7fc2e82deee32dc122f3b53b6dc1a
BLAKE2b-256 0fb2baf4d9fa4a08d8426d4632b2c979d10a6177a65f39979f87c1c2cec18dcb

See more details on using hashes here.

File details

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

File metadata

  • Download URL: srsly-2.4.0-cp38-cp38-macosx_10_9_x86_64.whl
  • Upload date:
  • Size: 449.8 kB
  • Tags: CPython 3.8, macOS 10.9+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.56.0 CPython/3.7.9

File hashes

Hashes for srsly-2.4.0-cp38-cp38-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 4ec1f3ada5873fd99c71ecaf6daf5bf9c5c9fb30bac90f1658d3f8a017cff98a
MD5 39f8ca6c68ee965c6e1591ad311caf6c
BLAKE2b-256 ff172f805603716fd2c64f250499f95314c386e15e5985e2bbdb34cf9e9f5cbc

See more details on using hashes here.

File details

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

File metadata

  • Download URL: srsly-2.4.0-cp37-cp37m-win_amd64.whl
  • Upload date:
  • Size: 449.7 kB
  • Tags: CPython 3.7m, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.56.0 CPython/3.7.9

File hashes

Hashes for srsly-2.4.0-cp37-cp37m-win_amd64.whl
Algorithm Hash digest
SHA256 b5c087dcf9f9113d588ee5f24f00581ef7f561353eb5784a431dbb0ee9bfe3bd
MD5 a768eb019f6d571f1ab2954a2d679b74
BLAKE2b-256 0083418a921a3c90002be29fb8af6c8fe236dab4270491dfd82fab57177439ce

See more details on using hashes here.

File details

Details for the file srsly-2.4.0-cp37-cp37m-manylinux2014_x86_64.whl.

File metadata

  • Download URL: srsly-2.4.0-cp37-cp37m-manylinux2014_x86_64.whl
  • Upload date:
  • Size: 456.2 kB
  • Tags: CPython 3.7m
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.56.0 CPython/3.7.9

File hashes

Hashes for srsly-2.4.0-cp37-cp37m-manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 81aa16f3cf7c7766a5b13e5daf25d729348067bc70c44c41f6a2bcf0b150dff5
MD5 f296b72b1fe50d0642dfbb9ad60a9afa
BLAKE2b-256 195476982427ceb495dd19ff982c966708c624b85e03c45bf1912feaf60c7b2d

See more details on using hashes here.

File details

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

File metadata

  • Download URL: srsly-2.4.0-cp37-cp37m-macosx_10_9_x86_64.whl
  • Upload date:
  • Size: 449.1 kB
  • Tags: CPython 3.7m, macOS 10.9+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.56.0 CPython/3.7.9

File hashes

Hashes for srsly-2.4.0-cp37-cp37m-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 5951ff0da7f20b5898fd788e9eaf0aa52a5fbf8f4208e3372bcde984a129335b
MD5 dcd22ff05d9c4ef487517e31fdd41118
BLAKE2b-256 3b46adc7a283db3067013b915fb26436c6c6ca39ee27aecb1bbefbd7fe3d59d7

See more details on using hashes here.

File details

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

File metadata

  • Download URL: srsly-2.4.0-cp36-cp36m-win_amd64.whl
  • Upload date:
  • Size: 449.8 kB
  • Tags: CPython 3.6m, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.56.0 CPython/3.7.9

File hashes

Hashes for srsly-2.4.0-cp36-cp36m-win_amd64.whl
Algorithm Hash digest
SHA256 6f8c8f72d2877a20ffe20baf587d21d9ed6e9fae5531ecc513e2411369d534a1
MD5 a098dce88a061c8305e9f65c77dafbd2
BLAKE2b-256 62333624a02117bb608023449144ec01398c7db8737c554eca8f42d6aa4fd52c

See more details on using hashes here.

File details

Details for the file srsly-2.4.0-cp36-cp36m-manylinux2014_x86_64.whl.

File metadata

  • Download URL: srsly-2.4.0-cp36-cp36m-manylinux2014_x86_64.whl
  • Upload date:
  • Size: 456.2 kB
  • Tags: CPython 3.6m
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.56.0 CPython/3.7.9

File hashes

Hashes for srsly-2.4.0-cp36-cp36m-manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 0d8ac57ee64bbb2f04af9680eea577e1f31c9804c334f25fab8bd074e51e5ae4
MD5 412fcfe872479f6afae7e8922ffb764a
BLAKE2b-256 4cb72a8da28c6b4db5137d6ba949f0160d4628582b1fef5665ead8bb96ac9346

See more details on using hashes here.

File details

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

File metadata

  • Download URL: srsly-2.4.0-cp36-cp36m-macosx_10_9_x86_64.whl
  • Upload date:
  • Size: 450.5 kB
  • Tags: CPython 3.6m, macOS 10.9+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.56.0 CPython/3.7.9

File hashes

Hashes for srsly-2.4.0-cp36-cp36m-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 9e55364151efaeb2811fc8dd222ece154cb74ababa57e878487b001c3ff2f8f6
MD5 4fd67c62b63a11455ec639ecc5090f17
BLAKE2b-256 fab0d7e96718e4aa751231e7a5f0ca5fee480394e0fb9ffd2a1195b9f23cddae

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