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. Default 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. Default to 4.
indent_offset int Indentation offset. Defaults to 2.
sort_keys bool Sort dictionary keys. Defaults to False.

function srsly.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.dev0.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.dev0-cp38-cp38-win_amd64.whl (455.4 kB view details)

Uploaded CPython 3.8Windows x86-64

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

Uploaded CPython 3.8

srsly-2.1.0.dev0-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.dev0-cp37-cp37m-win_amd64.whl (453.6 kB view details)

Uploaded CPython 3.7mWindows x86-64

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

Uploaded CPython 3.7m

srsly-2.1.0.dev0-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.dev0-cp36-cp36m-win_amd64.whl (453.6 kB view details)

Uploaded CPython 3.6mWindows x86-64

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

Uploaded CPython 3.6m

srsly-2.1.0.dev0-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.dev0.tar.gz.

File metadata

  • Download URL: srsly-2.1.0.dev0.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.dev0.tar.gz
Algorithm Hash digest
SHA256 9531ff0be262ac4397ace6192871b0a20c05f3b12aa946d0f6426c1f088fef37
MD5 207be0e2dc3b7d2b633d47ae0669ff71
BLAKE2b-256 27343afac03806c797002bbb2a596c40617672bdf776caac7aa0174d50b16a28

See more details on using hashes here.

File details

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

File metadata

  • Download URL: srsly-2.1.0.dev0-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.dev0-cp38-cp38-win_amd64.whl
Algorithm Hash digest
SHA256 174df783662b57fbd4ddd7e21d0060cd225ef58563e73e29b24678fe3f6f5c0d
MD5 0981aefaf38560614724090079a5c7f1
BLAKE2b-256 f20843f6b59bf4c19a9b2f77f12b18df89424555f73ecec6d2f81c55d835850d

See more details on using hashes here.

File details

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

File metadata

  • Download URL: srsly-2.1.0.dev0-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.dev0-cp38-cp38-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 f0cd1ce5cca7f78feb8e3f8a769697dfd39b1f93b3bb0215f6f0e33c0b4e8326
MD5 d681c606853a16dada34936c56b7b298
BLAKE2b-256 8ad9b1d6a9deebd9da9019057c03ef7c653ceb13251bf8c02416defb2b34ba86

See more details on using hashes here.

File details

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

File metadata

  • Download URL: srsly-2.1.0.dev0-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.dev0-cp38-cp38-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 6d12d7a8b129761d605d4080bc9b98c2a3881f81c5b5291e7ccaef0bd0ca9595
MD5 136c5a61759722979c4cf63f9e8c2328
BLAKE2b-256 2d5d4c6d614eb52b5b36449060fb07df0b3cbc467d4f82d6a049efed587d65de

See more details on using hashes here.

File details

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

File metadata

  • Download URL: srsly-2.1.0.dev0-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.dev0-cp37-cp37m-win_amd64.whl
Algorithm Hash digest
SHA256 0811f07465e3666bf398e87e5d858418fe84bf61d4deb2024827762e4ec64597
MD5 0ce2fb0bdeddb31146e16bfc805a0344
BLAKE2b-256 fa48676cd0ebf60d3cdabdef65a18416d2b4cab25011fce69847b622bd110928

See more details on using hashes here.

File details

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

File metadata

  • Download URL: srsly-2.1.0.dev0-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.dev0-cp37-cp37m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 5d6eb77b144787421c838cd4aea60b49f0038872ca2e5adcf4f17f788c3e315f
MD5 35852d6c6f2e0699586b5c040699002c
BLAKE2b-256 321bea79c32dd16deaf89765c80e5bf74f1e7ae7862c7781682e840e911c98c6

See more details on using hashes here.

File details

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

File metadata

  • Download URL: srsly-2.1.0.dev0-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.dev0-cp37-cp37m-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 e63ff4badf16a4f3ad43085932a2d45ba2efb3fc1c458f57beaf72ee7cb0f8f8
MD5 9b389bf87af26ac669426b4829fe05bf
BLAKE2b-256 d5588dd1cf1ca6467ee6a98665f25d5bbe703a72b88a09f75d4291dee1fe688b

See more details on using hashes here.

File details

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

File metadata

  • Download URL: srsly-2.1.0.dev0-cp36-cp36m-win_amd64.whl
  • Upload date:
  • Size: 453.6 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.dev0-cp36-cp36m-win_amd64.whl
Algorithm Hash digest
SHA256 de501c5b0c9a316971351d6bf50fa728507c7d83c96db2839eb390c5f2379030
MD5 61bb0a6a53166bdc96fe700fd0f94804
BLAKE2b-256 f719ca9c4827d065e9a56e3f1933e2f23696af303d5ca84215045c4364149bd4

See more details on using hashes here.

File details

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

File metadata

  • Download URL: srsly-2.1.0.dev0-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.dev0-cp36-cp36m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 ffb7367c1614d249b9274a5a239162271b7ba34426b39046b93f37d6104abb4a
MD5 b8ea190cca777db72601288f45fb0e96
BLAKE2b-256 d8491af6dd480c32a04770a44b973be308ac45a8cb6b10ea888193d3efed8f86

See more details on using hashes here.

File details

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

File metadata

  • Download URL: srsly-2.1.0.dev0-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.dev0-cp36-cp36m-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 63edb9b882b8d4896d7288ed5477daf1a71ab8000f80fb40a817bbc66c6a286a
MD5 c7e8fa1d364fb5012be9e8be472fab50
BLAKE2b-256 19477c55e0629b6e227b97e2593ee9fd35fd46f2e64028571b71fad5b12694e2

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