Python wrapper for jsonbox.io
Project description
jsonbox-python
Python wrapper for https://jsonbox.io (with support for V2 features)
Installation
pip install jsonbox
Usage
from jsonbox import JsonBox
# generate unique box id
MY_BOX_ID = JsonBox.get_new_box_id()
# create instance
jb = JsonBox()
data = [{"name": "first", "age": 25}, {"name": "second", "age": 19}]
# write data
result = jb.write(data, MY_BOX_ID)
# get record id of written data
record_ids = jb.get_record_id(result)
# read record
print(jb.read(MY_BOX_ID, record_ids[0]))
# read all records in box
print(jb.read(MY_BOX_ID))
# get metadata for box
print(jb.get_meta(MY_BOX_ID))
# read all records in box with sort
print(jb.read(MY_BOX_ID, sort_by="age"))
# read records in box with sort matching query (see documentation for syntax)
print(jb.read(MY_BOX_ID, query="name:firs*"))
print(jb.read(MY_BOX_ID, query="age:=19"))
# read records with limit
print(jb.read(MY_BOX_ID, limit=1))
# read records with skip
print(jb.read(MY_BOX_ID, skip=1))
# update data
data = {"name": "Bob", "age": 23}
jb.update(data, MY_BOX_ID, record_ids[0])
# read updated data
print(jb.read(MY_BOX_ID))
print(jb.read(MY_BOX_ID, record_ids[0]))
# delete records matching to query
print(jb.delete(MY_BOX_ID, query="age:=23"))
# delete records
jb.delete(MY_BOX_ID, record_ids[1])
# write to a private box
MY_PRIVATE_BOX_ID = JsonBox.get_new_box_id()
api_key = jb.get_new_api_key()
result = jb.write(data, MY_PRIVATE_BOX_ID, api_key=api_key)
record_id = jb.get_record_id(result)
# update a private box
data = {"name": "David", "age": 35}
jb.update(data, MY_PRIVATE_BOX_ID, record_id, api_key=api_key)
# delete a private box
jb.delete(MY_PRIVATE_BOX_ID, record_id, api_key=api_key)
Private Box
Add api_key
to write/update/delete as shown above.
read is always accessible, even with out an api_key
.
A valid and unique api_key
can be generated using get_new_api_key()
Query Params
As supported (and documented) by https://github.com/vasanthv/jsonbox
You can query by constructing a query string and passing it to the query
parameter:
name:arya%20stark,age:>13
The above sample will look for the name arya stark
and age greater than 13.
You can filter on Number
, String
& Boolean
values only.
Filters for Numeric values.
Sample | |
---|---|
To filter values greater than or less than a specific value | age:>10 or age:<10 |
To filter values greater (or less) than or equal to a specific value | age:>=10 or age:<=10 |
To filter values that match a specific value. | age:=10 |
Filters for String values.
Sample | |
---|---|
Filter values that start with a specific string | name:arya* |
Filter values that end with a specific string | name:*stark |
Filter values where a specific string appears anywhere in a string | name:*ya* |
Filter values that match a specific string | name:arya%20stark |
You can combine multiple fields by separating them with commas as shown below:
name:arya%20stark,age:>13,isalive:true
Deleting records
There are two ways to delete records (see examples above for both)
- Provide the
record_id
- Provide a
query
parameter, with the same syntax used for filtering on read
Use your own instance of jsonbox
jb = JsonBox(service_host="https://my-jsonbox-server.com")
License
MIT
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 Distribution
Built Distribution
File details
Details for the file jsonbox-1.2.1.tar.gz
.
File metadata
- Download URL: jsonbox-1.2.1.tar.gz
- Upload date:
- Size: 3.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.14.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.35.0 CPython/2.7.15
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 52ee1634e58c908efde8e62df34d50eb2c1e3811e0a9425751eaa0bc8a80e58b |
|
MD5 | 13a20d52691c8efc680803bf96c019e8 |
|
BLAKE2b-256 | d532a0096c9ee7662bfce6003f7c0c077b7790c3cbb46858c0f8405223cf8195 |
File details
Details for the file jsonbox-1.2.1-py2-none-any.whl
.
File metadata
- Download URL: jsonbox-1.2.1-py2-none-any.whl
- Upload date:
- Size: 4.7 kB
- Tags: Python 2
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.14.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.35.0 CPython/2.7.15
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 13d74eabd167d4453f9ce4ee82865ab3f505307af4529c74e4ce69562c5000fa |
|
MD5 | 3513192fe9f6fb0fa8ebfc50597bf8d5 |
|
BLAKE2b-256 | 1faf88bd879af59121006afd9d56ae55fcf5d37d36ebca3c450594131e43daf1 |