- Как найти конкретное значение JSON по ключу?
- 8 ответов
- How to search for data in JSON using python
- Example-1: Search key in simple JSON data
- Example-2: Search a particular value in JSON data
- Example-3: Search value in JSON array data using the custom function
- Example-4: Search key in nested JSON data
- Example-5: Search entry from a JSON file using filter method and lambda
- Conclusion:
- About the author
- Fahmida Yesmin
Как найти конкретное значение JSON по ключу?
Как я могу найти все значение P1 без его повторения всех json? PS: P1 может быть где угодно в json. Если ни один метод не может это сделать, можете ли вы рассказать мне, как выполнять итерацию через json?
Если это может быть где-то в наборе вложенных структур, то вам придется просмотреть все это. Вот так работает реальность.
8 ответов
Мой подход к этой проблеме будет другим.
Поскольку JSON не разрешает поиск по глубине сначала, переведите json в объект Python, передайте его в XML-декодер, а затем извлеките Node, который вы собираетесь искать
from xml.dom.minidom import parseString import json def bar(somejson, key): def val(node): # Searches for the next Element Node containing Value e = node.nextSibling while e and e.nodeType != e.ELEMENT_NODE: e = e.nextSibling return (e.getElementsByTagName('string')[0].firstChild.nodeValue if e else None) # parse the JSON as XML foo_dom = parseString(xmlrpclib.dumps((json.loads(somejson),))) # and then search all the name tags which are P1's # and use the val user function to get the value return [val(node) for node in foo_dom.getElementsByTagName('name') if node.firstChild.nodeValue in key] bar(foo, 'P1') [u'cccc', u'aaa', u'ss'] bar(foo, ('P1','P2')) [u'cccc', u'cccc', u'aaa', u'ss']
@JafferWilson: Документация Python 2 гласит: «Модуль xmlrpclib был переименован в xmlrpc.client в Python 3.» Документация по Python 3 находится здесь .
к сожалению, кажется, что он работает только тогда, когда значение является строкой или я делаю что-то не так.
@Abhijit Я согласен, но то, что я имел в виду, это bar(foo, ‘Id’) что приводит к ошибке, потому что значение для ключа Id — int.
Как я уже сказал в своем другом ответе, я не думаю, что есть способ найти все значения, связанные с ключом «P1» , без повторения всей структуры. Однако я придумал еще лучший способ сделать то, что пришло ко мне, глядя на принятый ответ на другой вопрос Как получить строковые объекты вместо Unicode из JSON?
Основная идея заключается в использовании параметра object_hook , который json.loads() принимает только для просмотра того, что декодируется и проверяет искомое значение. Примечание: Это будет работать, только если представление представляет собой JSON Object (т.е. что-то, заключенное в фигурные скобки <> ), как в вашем примере json.
import json def find_values(id, json_repr): results = [] def _decode_dict(a_dict): try: results.append(a_dict[id]) except KeyError: pass return a_dict json.loads(json_repr, object_hook=_decode_dict) # Return value ignored. return results json_repr = ', "P3": []>' print find_values('P1', json_repr)
У меня была такая же проблема только на днях. Я запустил только поиск по всему объекту и учитывал как списки, так и dicts. Следующие фрагменты позволяют вам искать первое вхождение нескольких ключей.
import json def deep_search(needles, haystack): found = <> if type(needles) != type([]): needles = [needles] if type(haystack) == type(dict()): for needle in needles: if needle in haystack.keys(): found[needle] = haystack[needle] elif len(haystack.keys()) > 0: for key in haystack.keys(): result = deep_search(needle, haystackПоиск по json питон) if result: for k, v in result.items(): found[k] = v elif type(haystack) == type([]): for node in haystack: result = deep_search(needles, node) if result: for k, v in result.items(): found[k] = v return found deep_search(["P1", "P3"], json.loads(json_string))
Он возвращает dict с ключами, которые искали ключи. Ожидается, что Haystack будет объектом Python, поэтому вам нужно будет выполнить json.loads перед тем, как передать его в deep_search.
Любые комментарии для оптимизации приветствуются!
Я знаю, что это старый ответ, но я просто хотел сказать, что я адаптировал ваше решение, отметив len(needles) == len(found) в обоих циклах, чтобы сократить выполнение в случае, если я уже нашел все ключи.
Использование json для преобразования json в объекты Python, а затем рекурсивно работает лучше всего. Этот пример включает просмотр списков.
import json def get_all(myjson, key): if type(myjson) == str: myjson = json.loads(myjson) if type(myjson) is dict: for jsonkey in myjson: if type(myjson[jsonkey]) in (list, dict): get_all(myjson[jsonkey], key) elif jsonkey == key: print myjson[jsonkey] elif type(myjson) is list: for item in myjson: if type(item) in (list, dict): get_all(item, key)
How to search for data in JSON using python
One of the most used data serialization technique is JSON format. Python has an in-built module JSON to work with JSON data. It supports all types of primitive data types such as number, string, etc, along with python objects. The data are stored in a structured format in JSON. Sometimes it is required to search a particular data from a large JSON string or a JSON file. There are many ways to search for specific data from JSON data. How JSON data can be searched based on key or value using the python script is shown in this article.
Example-1: Search key in simple JSON data
The following script shows how to search if a particular key exists in a JSON string or not. Here, a variable named customerData is defined to store the JSON data. The value of the key will be taken as input from the user. loads() method of JSON module is used to load JSON data in the variable named customer. Next, ‘in’ operator is used to search the key.
# Import json module
import json
# Define json data
customerData = «»» «id»: «3425678»,
«name»: «John Micheal»,
«email»: «john@gmail.com»,
«type»: «regular»,
«address»: «4258 Poplar Chase Lane, Boise, Idaho.»
>»»»
# Input the key value that you want to search
keyVal = input ( «Enter a key value: \n » )
# load the json data
customer = json. loads ( customerData )
# Search the key value using ‘in’ operator
if keyVal in customer:
# Print the success message and the value of the key
print ( «%s is found in JSON data» %keyVal )
print ( «The value of» , keyVal , «is» , customer [ keyVal ] )
else :
# Print the message if the value does not exist
print ( «%s is not found in JSON data» %keyVal )
The script is executed two times here. An existing key value is given for the first time and a non-existing key value is given for the second time.
Example-2: Search a particular value in JSON data
The following script shows how to search a particular value in JSON data. applicants variable contains the JSON data where the key is used to store the applicant’s name and value is used to store the applicant is present or absent. The script will search the ‘Absent’ value in the JSON data and print the corresponding name value. for loop is used here iterate the JSON data.
# Import json module
import json
# Define json data
applicants = «»» «Scott C Aldridge»: «Present»,
«Joe L Foss»: «Present»,
«Clyde M Gold»: «Present»,
«Monique C Doolittle»: «Absent»,
«David M Volkert»: «Present»,
«Israel M Oneal»: «Present»,
«Elizabeth M Groff»: «Absent»
>»»»
# Initialize a counter
counter = 0
# load the json data
appList = json. loads ( applicants )
# iterate json to find the list of absent applicant
for key in appList:
if ( appList [ key ] == ‘Absent’ ) :
# Check the counter the print the message
if ( counter == 0 ) :
print ( «The following applicants are absent:» )
print ( key )
counter = counter + 1
# Print the message if no applicant is absent
if ( counter == 0 ) :
print ( «All applicants are present» )
According to the JSON data from the script, two applicants are absent. This will be the resulting output after running the script:
Example-3: Search value in JSON array data using the custom function
In the following script, a JSON array named jsondata is defined. A particular value of a key will be searched here and if the value exists then the value of another related key will be printed as output. search_price() function is defined here take the value of the name key that will be searched in the JSON data and it will print the value of the corresponding unit_price key.
# Import json module
import json
# Define json variable
jsondata = «»»[
«name»:»Pen»,
«unit_price»:5
>,
«name»:»Eraser»,
«unit_price»:3
>,
«name»:»Pencil»,
«unit_price»:10
>,
«name»:»White paper»,
«unit_price»:15
>
]»»»
# load the json data
items = json. loads ( jsondata )
# Input the item name that you want to search
item = input ( «Enter an item name: \n » )
# Define a function to search the item
def search_price ( name ) :
for keyval in items:
if name. lower ( ) == keyval [ ‘name’ ] . lower ( ) :
return keyval [ ‘unit_price’ ]
# Check the return value and print message
if ( search_price ( item ) != None ) :
print ( «The price is:» , search_price ( item ) )
else :
print ( «Item is not found» )
The script is executed two times in this output. ‘pencil’ is taken as the value of the name key that exists in the JSON data. The unit_price of ‘pencil’ is 10 that is printed. Next, ‘book’ is taken as an input value that doesn’t exist in the JSON data.
Example-4: Search key in nested JSON data
The following script shows steps on searching the value of a particular key in the nested JSON data. Here, a nested JSON variable named nestedData is declared to store nested data. This script will search the brand name of the women watch.
# Import json module
import json
# Define json variable of nested data
nestedData = «»» «watch»: «men»: «brand»:»Titan»,
«price»:200
>,
«women»: «brand»:»Citizen»,
«price»:250
>,
«kid»: «brand»:»Blancpain»,
«price»:100
>
>
>»»»
# Load the json data
watchlist = json. loads ( nestedData )
# Search ‘brand’ for women
if ‘brand’ in watchlist [ ‘watch’ ] [ ‘women’ ] :
print ( watchlist [ ‘watch’ ] [ ‘women’ ] [ ‘brand’ ] )
In the above script, there is only one brand value for women watch which is ‘Citizen’. The following will be the output after running the script.
Example-5: Search entry from a JSON file using filter method and lambda
The following steps show how you can search the entry from a JSON file based on a particular key and values. The content of books.json file is given below.
[{
«isbn» : «7799349885» ,
«name» : «Essentials of Vehicle Dynamics» ,
«author» : «Joop P. Pauwelussen»
} ,
{
«isbn» : «7799349885» ,
«name» : «Flow and Combustion in Reciprocating Engines» ,
«author» : «C. Arcoumanis and T. Kamimoto»
} ,
{
«isbn» : «7799349885» ,
«name» : «Automotive Ergonomics Driver Vehicle Interaction» ,
«author» : «Nikolaos Gkikas»
}
]
The following script will search the entry from books.json file, where the value of the author key is Nikolaos Gkikas using lambda and filter() method.
# Import JSON module
import json
# Open the existing JSON file for loading into a variable
with open ( ‘books.json’ ) as jsondata:
data = json. load ( jsondata )
# Search data based on key and value using filter and list method
print ( list ( filter ( lambda x:x [ «author» ] == «Nikolaos Gkikas» , data ) ) )
The following output will appear after running the script.
Conclusion:
When working with a large amount of JSON data and need to find out the specific information from the data with ease, we have to use efficient ways to do the task. Different ways of searching key and value in JSON data are explained in this article to help python users to perform the process successfully.
About the author
Fahmida Yesmin
I am a trainer of web programming courses. I like to write article or tutorial on various IT topics. I have a YouTube channel where many types of tutorials based on Ubuntu, Windows, Word, Excel, WordPress, Magento, Laravel etc. are published: Tutorials4u Help.