[英]Accessing data from a JSON file
我对JSON很陌生。 我的代码包含从需要API密钥的网站提取数据。 提取了信息。 我正在尝试通过这种格式(以下为示例)来获取以Son编码的信息:
[{"number":31705,"name":"31705 - CHAMPEAUX (BAGNOLET)","address":"RUE DES CHAMPEAUX (PRES DE LA GARE ROUTIERE) - 93170 BAGNOLET","latitude":48.8645278209514,"longitude":2.416170724425901},{"number":10042,"name":"10042 - POISSONNIÈRE - ENGHIEN","address":"52 RUE D'ENGHIEN / ANGLE RUE DU FAUBOURG POISSONIERE - 75010 PARIS","latitude":48.87242006305313,"longitude":2.348395236282807}]
如何访问json代码中的不同数据? 这是我想出的代码:
import requests
reponse=requests.get('https://api.jcdecaux.com/vls/v1/stations/{station_number}?contract={contract_name}&api_key HTTP/1.1')
我相信我的请求已经制定了一个响应,该响应位于网站发送到我的计算机的“响应”“文件夹”中:
print(reponse.headers)
print(reponse(2,/'latitude')
我正在尝试在json代码的每个元素中访问纬度信息-2表示列表的第二个元素,纬度是我要在json列表元素内访问的值的名称。 但是我做不到。 我得到的错误是语法错误。
我如何解决它? 我想访问对象“响应”的每个成员的每个字符串的所有值。
更新n°1:
我的新代码是:
import json
import requests
reponse=requests.get('https://api.jcdecaux.com/vls/v1/stations/{31705}?contract={Paris}&apiKey={0617697a9795f803697de4b9abf9759d5406b3a0} HTTP/1.1')
data = json.loads(response.content)
print(data)
但是我得到了错误:
Traceback (most recent call last):
File "/Users/someone/Desktop/TIPE 2016:17/Programme TIPE 2016:2017.py", line 27, in <module>
data = json.loads(response.content)
File "/Users/someone/miniconda3/lib/python3.5/json/__init__.py", line 312, in loads
s.__class__.__name__))
TypeError: the JSON object must be str, not 'bytes'
更新n°2:
我的新代码是:
import json
import requests
reponse=requests.get('https://api.jcdecaux.com/vls/v1/stations/{31705}?contract={Paris}&apiKey={0617697a9795f803697de4b9abf9759d5406b3a0} HTTP/1.1')
data = response.json()
latitude = data[2]['latitude']
但是我得到了错误:
Traceback (most recent call last):
File "/Users/someone/Desktop/TIPE 2016:17/Programme TIPE 2016:2017.py", line 30, in <module>
latitude = data[2]['latitude']
KeyError: 2
这是否意味着响应为空?
更新n°3:
reponse.content
答案如下:
b'{ "error" : "Unauthorized" }'
问题是什么 ?
第4次更新:
我的新代码是:
reponse=requests.get('https://api.jcdecaux.com/vls/v1/stations/{31705}?contract={Paris}&apiKey={0617697a9795f803697de4b9abf9759d5406b3a0} HTTP/1.1')
data = json.loads(response.content.decode('utf-8'))
print(reponse.headers)
print(reponse.content)
结果是:
{'Content-Length': '48', 'Content-Encoding': 'gzip', 'Server': 'Apache-Coyote/1.1', 'Date': 'Fri, 23 Sep 2016 19:39:25 GMT', 'Connection': 'close', 'Content-Type': 'application/json'}
b'{ "error" : "Unauthorized" }'
因此,对我的请求的回答不是空的,但我没有访问它的权限。 我该如何解决?
最后更新:
新的工作代码是:
import json
import requests
r = requests.get('https://api.jcdecaux.com/vls/v1/stations/31705?contract=Paris&apiKey=0617697a9795f803697de4b9abf9759d5406b3a0')
response_json = r.json()
print (response_json['name'])
结果是:
31705 - CHAMPEAUX (BAGNOLET)
您可以将json
数据转换为dict,然后像字典一样访问它。 我相信应该是这样
data = json.loads(response.content.decode('utf-8'))
您弄乱了网址。 我不确定HTTP/1.1
后缀是什么,但是id绝对不属于这里。 此外,括号中的所有参数都看起来不正确。
import requests
r = requests.get('https://api.jcdecaux.com/vls/v1/stations/31705?contract=Paris&apiKey=0617697a9795f803697de4b9abf9759d5406b3a0')
response_json = r.json()
print response_json
此代码段显示:
{u'status': u'OPEN', u'contract_name': u'Paris', u'name': u'31705 - CHAMPEAUX (BAGNOLET)', u'bonus': True, u'bike_stands': 50, u'number': 31705, u'last_update': 1474660046000, u'available_bike_stands': 49, u'banking': True, u'available_bikes': 1, u'address': u'RUE DES CHAMPEAUX (PRES DE LA GARE ROUTIERE) - 93170 BAGNOLET', u'position': {u'lat': 48.8645278209514, u'lng': 2.416170724425901}}
综上所述, response_json
现在是标准的Python字典,可以使用标准dict协议从中访问数据。
print response_json['status'] # prints OPEN
请求具有内置的JSON解码器,因此无需使用json库:
import requests
response = requests.get(url)
data = response.json()
根据问题的详细信息,“数据” 可能是包含纬度的词典列表。 因此,提取第一个可能是:
latitude = data[0]['latitude']
但是您可能需要首先以交互方式进行响应以确保。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.