Skip to main content

A JSON streaming writer

Project description

https://travis-ci.org/dcbaker/jsonstreams.svg?branch=master https://ci.appveyor.com/api/projects/status/ocrt9nol8kn3pm1t/branch/master?svg=true

Source code is available at github.

The code is licensed MIT. See the included LICENSE file for the exact terms.

Description

JSONstreams is a package that attempts to making writing JSON in a streaming format easier. In contrast to the core json module, this package doesn’t require building a complete tree of dicts and lists before writing, instead it provides a straightforward way to to write a JSON document without building the whole data structure ahead of time.

JSONstreams considers there to be two basic types, the JSON array and the JSON object, which correspond to Python’s list and dict respectively, and can encode any types that the json.JSONEncoder can, or can use an subclass to handle additional types.

The interface is designed to be context manger centric. The Stream class, and the Array and Object classes returned by the subarray and subobject methods (respectively), can be used as context managers or not, but use as context managers are recommended to ensure that each container is closed properly.

Basic Usage

A simple use looks like this:

with jsonstreams.Stream('foo', 'object') as s:
    s.write('foo', 'bar')
    with s.subobject('a') as a:
        a.write(1, 'foo')
        a.write(2, 'bar')
    s.write('bar', 'foo')

Writing into a closed group will raise an exception, which should not be handled, this exception is always an error in programming and should be corrected.

It is possible to write any value that the encoder (json.JSONEncoder by default) can encode, so iterating over lists or dictionaries to write them in is unnecessary:

mylist = list(range(10))
mydict = {a, b, for a in range(10), for b in 'abcdefghij'}

with jsonstreams.Stream('foo', 'object') as s:
    s.write('list', mylist)
    s.write('dict', mydict)

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

jsonstreams-0.3.1.tar.gz (8.0 kB view details)

Uploaded Source

Built Distribution

jsonstreams-0.3.1-py2.py3-none-any.whl (10.7 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file jsonstreams-0.3.1.tar.gz.

File metadata

  • Download URL: jsonstreams-0.3.1.tar.gz
  • Upload date:
  • Size: 8.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for jsonstreams-0.3.1.tar.gz
Algorithm Hash digest
SHA256 41a7f787692fc170aff94702376cf972d1ed9678638c1b8340cb9ac15d372ed7
MD5 9f1ebd5b2d6adab90028dbf19c7ed8e3
BLAKE2b-256 b64efc68910cc9b72bca0f9ee8d8cdc7d3ef55c03ab62b2dfb9338d74639f11c

See more details on using hashes here.

File details

Details for the file jsonstreams-0.3.1-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for jsonstreams-0.3.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 51260ca372af4f686a100edcf0c6c93d5c9d4734346023ad4210264927ac4e06
MD5 9de86ea6d5d83505bf828f49663e19c2
BLAKE2b-256 fd66988affda28666dc4f2348700b2ff680047acb2910d88f19936d1979828a6

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page