Pular para o conteúdo
🛠️ToolsShed

JSONPath Tester

Teste expressões JSONPath contra dados JSON.

Sobre esta ferramenta

JSONPath é uma linguagem de consulta para dados JSON, similar ao XPath para XML. O Testador de JSONPath ajuda desenvolvedores e analistas de dados a validar e depurar expressões JSONPath testando-as diretamente contra documentos JSON de exemplo. Esta ferramenta elimina a adivinhação ao trabalhar com APIs, arquivos de configuração ou estruturas de dados complexas que exigem navegação de caminho precisa.

Para usar a ferramenta, cole seus dados JSON no campo de entrada e digite uma expressão JSONPath no campo de expressão. Conforme você digita, o testador mostra imediatamente quais elementos correspondem à sua expressão, juntamente com seus valores. Os padrões comuns incluem $. para acesso raiz, .property para propriedades de objetos, [0] para índices de matriz e [*] para selecionar todos os elementos da matriz. Os resultados exibem todos os caminhos e valores correspondentes, facilitando o refinamento de sua consulta até extrair exatamente o que você precisa.

Perguntas Frequentes

Implementação de Código

# 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.