Natural language to DSL agent for JSON querying
🔗 Main site • 🐦 Twitter • 📢 Discord • 🖇️ AgentOps
Replicable, AI-generated JSON transformation queries. Transform any JSON into any schema automatically.
Jaiqu is an AI agent for creating repeatable JSON transforms using jq query language syntax. Jaiqu translates any arbitrary JSON inputs into any desired schema.
Building AI agents? Check out AgentOps
- Translate any schema to any schema AI agent automatically maps data from a source schema to a desired format by iteratively prompting GPT-4 to create valid jq query syntax.
- Schema validation Given a requirement schema, automatically validate whether the required data is present in the input json.
- Fuzzy term matching Infers keys based on symantic similarity (i.e. datetime vs date_time). GPT-4 automaticlaly maps and translates input keys to desired output keys.
from jaiqu import validate_schema, translate_schema
# Desired data format
schema = {
"$schema": "http://json-schema.org/draft-07/schema#",
"type": "object",
"properties": {
"id": {
"type": ["string", "null"],
"description": "A unique identifier for the record."
},
"date": {
"type": "string",
"description": "A string describing the date."
},
"model": {
"type": "string",
"description": "A text field representing the model used."
}
},
"required": [
"id",
"date"
]
}
# Provided data
input_json = {
"call.id": "123",
"datetime": "2022-01-01",
"timestamp": 1640995200,
"Address": "123 Main St",
"user": {
"name": "John Doe",
"age": 30,
"contact": "[email protected]"
}
}
# (Optional) Create hints so the agent knows what to look for in the input
key_hints="We are processing outputs of an containing an id, a date, and a model. All the required fields should be present in this input, but the names might be different."
Validating an input json contains all the information required in a schema
schema_properties, valid = validate_schema(input_json, schema, key_hints)
print(schema_properties)
>>> {
"id": {
"identified": true,
"key": "call.id",
"message": "123",
"type": [
"string",
"null"
],
"description": "A unique identifier for the record.",
"required": true
},
"date": {
"identified": true,
"key": "datetime",
"message": "2022-01-01",
"type": "string",
"description": "A string describing the date."
"required": true
}
}
print(valid)
>>> True
Creating a repeatable jq query for extracitng data from identically formatted input JSONs
jq_query = jaiqu.translate_schema(input_json, schema, key_hints, max_retries=30)
>>>'{"id": .attributes["call.id"], "date": .datetime}'
git clone https://github.com/AgentOps-AI/Jaiqu.git
cd Jaiqu/samples/
jaiqu -s schema.json -d data.json
# Validating schema: 100%|███████████████████████████| 3/3 [00:11<00:00, 3.73s/it, Key: model]
# Translating schema: 100%|███████████████████████████| 2/2 [00:02<00:00, 1.46s/it, Key: date]
# Retry attempts: 20%|███████████████████▌ | 2/10 [00:02<00:11, 1.46s/it]
# Validation attempts: 10%|█████████▎ | 1/10 [00:00<00:08, 1.02it/s]
jq '{ "id": (if .["call.id"] then .["call.id"] else null end), "date": (if has("datetime") then .datetime else "None" end) }' data.json
# Run command?
# [E]xecute, [A]bort: e
# {
# "id": "123",
# "date": "2022-01-01"
# }
Note: usage is currently limited to python 3.9 & 3.10
Recommended: PyPI:
pip install jaiqu
Unraveling the Jaiqu agentic workflow pattern
flowchart TD
A[Start translate_schema] --> B{Validate input schema}
B -- Valid --> C[For each key, create a jq filter query]
B -- Invalid --> D[Throw RuntimeError]
C --> E[Compile and Test jq Filter]
E -- Success --> F[Validate JSON]
E -- Fail --> G[Retry Create jq Filter]
G -- Success --> E
G -- Fail n times--> H[Throw RuntimeError]
F -- Success --> I[Return jq query string]
F -- Fail --> J[Retry Validate JSON]
J -- Success --> I
J -- Fail n times --> K[Throw RuntimeError]
- Install
pytest
if you don't have it already
pip install pytest
- Run the
tests/
folder while in the parent directory
pytest tests
This repo also supports tox
, simply run python -m tox
.
Contributions to Jaiqu are welcome! Feel free to create an issue for any bug reports, complaints, or feature suggestions.
Jaiqu is released under the MIT License.