Skip to main content

An implementation of JSON Schema validation for Python

Project description

jsonschema is an implementation of JSON Schema for Python (supporting 2.6+ including Python 3).

>>> from jsonschema import validate

>>> # A sample schema, like what we'd get from json.load()
>>> schema = {
...     "type" : "object",
...     "properties" : {
...         "price" : {"type" : "number"},
...         "name" : {"type" : "string"},
...     },
... }

>>> # If no exception is raised by validate(), the instance is valid.
>>> validate({"name" : "Eggs", "price" : 34.99}, schema)

>>> validate(
...     {"name" : "Eggs", "price" : "Invalid"}, schema
... )                                   # doctest: +IGNORE_EXCEPTION_DETAIL
Traceback (most recent call last):
    ...
ValidationError: 'Invalid' is not of type 'number'

Features

Release Notes

v0.8.0 introduces full support for JSON references via the RefResolver object. It also removes all of the deprecated code from v0.7.

Other notable fixes are a fix for improper support of uniqueItems for True and False (#34) and any for unknown types (#47).

Notably, there now exists some documentation (woo hoo!). It can be found at:

http://python-jsonschema.readthedocs.org

There are still a few incomplete sections, but it’s mostly there. Patches welcome for weak points.

Running the Test Suite

jsonschema uses the wonderful Tox for its test suite. (It really is wonderful, if for some reason you haven’t heard of it, you really should use it for your projects).

Assuming you have tox installed (perhaps via pip install tox or your package manager), just run tox in the directory of your source checkout to run jsonschema’s test suite on all of the versions of Python jsonschema supports. Note that you’ll need to have all of those versions installed in order to run the tests on each of them, otherwise tox will skip (and fail) the tests on that version.

Contributing

I’m Julian Berman.

jsonschema is on GitHub.

Get in touch, via GitHub or otherwise, if you’ve got something to contribute, it’d be most welcome!

You can also generally find me on Freenode (nick: tos9) in various channels, including #python.

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distributions

jsonschema-0.8.0.zip (26.9 kB view details)

Uploaded Source

jsonschema-0.8.0.tar.gz (17.8 kB view details)

Uploaded Source

File details

Details for the file jsonschema-0.8.0.zip.

File metadata

  • Download URL: jsonschema-0.8.0.zip
  • Upload date:
  • Size: 26.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for jsonschema-0.8.0.zip
Algorithm Hash digest
SHA256 e9ae328244bb53023df620e76fd5affaaef6a5d92b9ce21054862949c93c2ba5
MD5 d3b18d69c116ec0a8ff045aa01e7c001
BLAKE2b-256 9db217a274276d300d4f4acb1ec85bc82392ac83a2fac314cf6bf91c36de3260

See more details on using hashes here.

File details

Details for the file jsonschema-0.8.0.tar.gz.

File metadata

  • Download URL: jsonschema-0.8.0.tar.gz
  • Upload date:
  • Size: 17.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for jsonschema-0.8.0.tar.gz
Algorithm Hash digest
SHA256 2db223fca5e285798ff7f15ce3595657abb148c628306d06c8ecc1c166542429
MD5 d7ce08ec89a66f2ff014ab58bee01359
BLAKE2b-256 7d9af77716541bb8558d8d61c9b2160835a70a15d2cf81b9d6c842067babd197

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