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.yaml", 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.yaml")
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.1.0.dev1.tar.gz (317.5 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.1.0.dev1-cp38-cp38-win_amd64.whl (455.4 kB view details)

Uploaded CPython 3.8Windows x86-64

srsly-2.1.0.dev1-cp38-cp38-manylinux1_x86_64.whl (456.7 kB view details)

Uploaded CPython 3.8

srsly-2.1.0.dev1-cp38-cp38-macosx_10_9_x86_64.whl (453.8 kB view details)

Uploaded CPython 3.8macOS 10.9+ x86-64

srsly-2.1.0.dev1-cp37-cp37m-win_amd64.whl (453.6 kB view details)

Uploaded CPython 3.7mWindows x86-64

srsly-2.1.0.dev1-cp37-cp37m-manylinux1_x86_64.whl (457.0 kB view details)

Uploaded CPython 3.7m

srsly-2.1.0.dev1-cp37-cp37m-macosx_10_9_x86_64.whl (452.7 kB view details)

Uploaded CPython 3.7mmacOS 10.9+ x86-64

srsly-2.1.0.dev1-cp36-cp36m-win_amd64.whl (453.7 kB view details)

Uploaded CPython 3.6mWindows x86-64

srsly-2.1.0.dev1-cp36-cp36m-manylinux1_x86_64.whl (456.8 kB view details)

Uploaded CPython 3.6m

srsly-2.1.0.dev1-cp36-cp36m-macosx_10_9_x86_64.whl (454.9 kB view details)

Uploaded CPython 3.6mmacOS 10.9+ x86-64

File details

Details for the file srsly-2.1.0.dev1.tar.gz.

File metadata

  • Download URL: srsly-2.1.0.dev1.tar.gz
  • Upload date:
  • Size: 317.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.24.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.46.1 CPython/3.7.7

File hashes

Hashes for srsly-2.1.0.dev1.tar.gz
Algorithm Hash digest
SHA256 84d8db7a5d376799c8fb5cad82e06e09d17cb3f60ff0d89f0e6ab335cd7289ce
MD5 53c4f8e9afa518e55fcaed07cc1e380a
BLAKE2b-256 96773182885a120d7bcbba7aaddd44e9c4e70c021bde91f443b28140b7e38777

See more details on using hashes here.

File details

Details for the file srsly-2.1.0.dev1-cp38-cp38-win_amd64.whl.

File metadata

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

File hashes

Hashes for srsly-2.1.0.dev1-cp38-cp38-win_amd64.whl
Algorithm Hash digest
SHA256 a9207d3868f5936453f6ff676c3feb108f0b6eacc7ceed9ee432ef8dfc3a9bde
MD5 0427f025e4b02223a97d114f6a4daacb
BLAKE2b-256 7fc094d726d51d154227aee425f64ae5d01caa46304dd94dd4ca7c6abeb714b3

See more details on using hashes here.

File details

Details for the file srsly-2.1.0.dev1-cp38-cp38-manylinux1_x86_64.whl.

File metadata

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

File hashes

Hashes for srsly-2.1.0.dev1-cp38-cp38-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 5b636648778af9d83c8d4df996a2ea9a280b57670f911f47dc98033599ae7f10
MD5 fa80d7f7832d807beac2ca1d9877e812
BLAKE2b-256 09c7f6b2571a8980eaf0a12cf267fc4a98db9d29cc66d1f8ae68e489df2ff716

See more details on using hashes here.

File details

Details for the file srsly-2.1.0.dev1-cp38-cp38-macosx_10_9_x86_64.whl.

File metadata

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

File hashes

Hashes for srsly-2.1.0.dev1-cp38-cp38-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 086a587eb051c390899fa9f2e81ba9172d14109a0a474732de583a7a8a549c01
MD5 6e17673863b54e7221c2e2d5f3884884
BLAKE2b-256 d48dbfc3c8f7ae97fc82b230a640d40d2c98766085550ebeb126efb323f01468

See more details on using hashes here.

File details

Details for the file srsly-2.1.0.dev1-cp37-cp37m-win_amd64.whl.

File metadata

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

File hashes

Hashes for srsly-2.1.0.dev1-cp37-cp37m-win_amd64.whl
Algorithm Hash digest
SHA256 cd5d78fc6ab9fb4b6a0862569a8c8e1f13eb93ab97e80dfb43e2ea4f20098dc3
MD5 cee299a85c45a92e4a6874466b35f8bf
BLAKE2b-256 d13cf1e5f990604dba367a96bb4bed7d712a3c6b85fad220cf2dc1f7502a64c8

See more details on using hashes here.

File details

Details for the file srsly-2.1.0.dev1-cp37-cp37m-manylinux1_x86_64.whl.

File metadata

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

File hashes

Hashes for srsly-2.1.0.dev1-cp37-cp37m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 dc6bbabf67a0b1f057c02712647c58884ac53c71d5e1831e91c465a391513ee1
MD5 026c337584a13fa3648ff160f872fad4
BLAKE2b-256 6caa8e855213873de938cac47655174afae3843457c04c4871a09c6f747a6415

See more details on using hashes here.

File details

Details for the file srsly-2.1.0.dev1-cp37-cp37m-macosx_10_9_x86_64.whl.

File metadata

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

File hashes

Hashes for srsly-2.1.0.dev1-cp37-cp37m-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 abba52d97619357f2a66fb2b9ab595d90a806c48460d76037f8acc8d62fda050
MD5 f972d833163607cf8e9f40d5dce47f15
BLAKE2b-256 603f0aed8bd65b11b5e8a7bb0b4a385506ba09da73a44a514327d82bcbdc74ec

See more details on using hashes here.

File details

Details for the file srsly-2.1.0.dev1-cp36-cp36m-win_amd64.whl.

File metadata

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

File hashes

Hashes for srsly-2.1.0.dev1-cp36-cp36m-win_amd64.whl
Algorithm Hash digest
SHA256 2868a4bb7b33cf8f3b33d235590269f29ca99fc12c77e30076f2235706711c1d
MD5 5e5ca5e9b584186cf9f847e674c42514
BLAKE2b-256 b354e61ef6a109f7bbeca43a5214fcdd8762051f0ff880b24db37b48fd307dd5

See more details on using hashes here.

File details

Details for the file srsly-2.1.0.dev1-cp36-cp36m-manylinux1_x86_64.whl.

File metadata

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

File hashes

Hashes for srsly-2.1.0.dev1-cp36-cp36m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 6c3902d4625c390b52166ef5a466c9f045b9fb2f0019af058ab730d5d21e7d47
MD5 a8dc27385aa88fedb307e1c5e3d72797
BLAKE2b-256 d918e622bcdd56b6f67fbb3f99119298c94d0629e9b6691647be8c271214d72b

See more details on using hashes here.

File details

Details for the file srsly-2.1.0.dev1-cp36-cp36m-macosx_10_9_x86_64.whl.

File metadata

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

File hashes

Hashes for srsly-2.1.0.dev1-cp36-cp36m-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 54018085b51984e24a895b2f93dae0d349d2a0ba772815a92b74714317101e44
MD5 ff588426be89ac41758cadf6b2106163
BLAKE2b-256 ad556db4ae812666dceeac18566747159e5d66753e8486c2955960821d1ac50f

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