Перейти к содержимому

JSONPath Tester

Протестируйте выражения JSONPath на JSON-данных.

Об этом инструменте

JSONPath — это язык запросов для данных JSON, аналогичный XPath для XML. Тестер JSONPath помогает разработчикам и аналитикам данных проверять и отлаживать выражения JSONPath, тестируя их непосредственно на примерах JSON-документов. Этот инструмент исключает необходимость в предположениях при работе с API, файлами конфигурации или сложными структурами данных, требующими точной навигации по пути.

Чтобы использовать инструмент, вставьте свои JSON-данные в поле ввода и введите выражение JSONPath в поле выражения. По мере ввода тестер немедленно показывает, какие элементы соответствуют вашему выражению, вместе с их значениями. Общие шаблоны включают $. для доступа к корню, .property для свойств объекта, [0] для индексов массива и [*] для выбора всех элементов массива. Результаты отображают все совпадающие пути и значения, что упрощает уточнение вашего запроса до получения именно того, что вам нужно.

Часто задаваемые вопросы

Реализация кода

# pip install jsonpath-ng
from jsonpath_ng import parse

data = {
    "store": {
        "book": [
            {"title": "Moby Dick", "author": "Herman Melville", "price": 8.99},
            {"title": "The Great Gatsby", "author": "F. Scott Fitzgerald", "price": 12.99},
            {"title": "1984", "author": "George Orwell", "price": 6.99}
        ]
    }
}

# Match all book titles
expr = parse("$.store.book[*].title")
titles = [match.value for match in expr.find(data)]
print(titles)
# ['Moby Dick', 'The Great Gatsby', '1984']

# Filter books cheaper than $10
expr2 = parse("$.store.book[?(@.price < 10)]")
cheap_books = [match.value for match in expr2.find(data)]
print(cheap_books)
# [{'title': 'Moby Dick', ...}, {'title': '1984', ...}]

# Recursive descent: find all authors anywhere in the document
expr3 = parse("$..author")
authors = [match.value for match in expr3.find(data)]
print(authors)
# ['Herman Melville', 'F. Scott Fitzgerald', 'George Orwell']

Comments & Feedback

Comments are powered by Giscus. Sign in with GitHub to leave a comment.