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

v2.0.0 adds a better interface for creating and extending validators in the form of jsonschema.validators.create and jsonschema.validators.extend. The documentation is still a bit lacking in this area but it’s getting there. See the tests in jsonschema.tests.test_validators and the source code if you’d like to try it out now. ValidatorMixin has been removed.

Practically speaking, this affects validators that subclassed a built-in validator and extended a validator function (presumably with an upcall via super), as the correct way to do so is now to call TheValidator.VALIDATORS["extended_validator_fn"] directly in a new validator function (and of course to use create). Examples hopefully coming soon if more clarification is needed. Patches welcome of course.

It also fixes a number of issues with ref resolution, one for array indices (#95) and one for improper handling of unknown URI schemes (#102).

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.

Of course you’re also free to just run the tests on a single version with your favorite test runner. The tests live in the jsonschema.tests package.

Community

There’s a mailing list for this implementation on Google Groups.

Please join, and feel free to send questions there.

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-2.0.0.zip (65.1 kB view details)

Uploaded Source

jsonschema-2.0.0.tar.gz (39.9 kB view details)

Uploaded Source

File details

Details for the file jsonschema-2.0.0.zip.

File metadata

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

File hashes

Hashes for jsonschema-2.0.0.zip
Algorithm Hash digest
SHA256 db49eff2752cc5f550b338c812131b2f0f90ef066b74a507bbc8efe41565690c
MD5 71d0f614329aa6b3474c02ff062ccaeb
BLAKE2b-256 fc74b12ab61c554ad173e999cf954a675be798f90f236a9ad429d41fb8663baf

See more details on using hashes here.

File details

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

File metadata

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

File hashes

Hashes for jsonschema-2.0.0.tar.gz
Algorithm Hash digest
SHA256 c2c8483be59aea3df568d8aad2b3296ef7ea767639efe6e0363c722f7f096322
MD5 1793d97a668760ef540fadd342aa08e5
BLAKE2b-256 c91fda11bf890ee8c99440fe0e0dd413e38abb984717b78e3891f16d998c554a

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