繁体   English   中英

从JSON文件访问数据

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM