从文件中读取JSON

一个简单的外表,简单的陈述在我面前抛出了一些错误。

我有一个名为strings.json的JSON文件,如下所示:

"strings": [{"-name": "city", "#text": "City"}, {"-name": "phone", "#text": "Phone"}, ...,
{"-name": "address", "#text": "Address"}]

现在我想读取JSON文件。我发现了这些陈述,但它不起作用:

import json
from pprint import pprint


with open('strings.json') as json_data:
d = json.loads(json_data)
json_data.close()
pprint(d)

控制台上显示的错误如下:

Traceback (most recent call last):
File "/home/.../android/values/manipulate_json.py", line 5, in <module>
d = json.loads(json_data)
File "/usr/lib/python2.7/json/__init__.py", line 326, in loads
return _default_decoder.decode(s)
File "/usr/lib/python2.7/json/decoder.py", line 366, in decode
obj, end = self.raw_decode(s, idx=_w(s, 0).end())
TypeError: expected string or buffer
[Finished in 0.1s with exit code 1]

如果我使用json.load而不是json.loads,我会得到这个错误:

Traceback (most recent call last):
File "/home/.../android/values/manipulate_json.py", line 5, in <module>
d = json.load(json_data)
File "/usr/lib/python2.7/json/__init__.py", line 278, in load
**kw)
File "/usr/lib/python2.7/json/__init__.py", line 326, in loads
return _default_decoder.decode(s)
File "/usr/lib/python2.7/json/decoder.py", line 369, in decode
raise ValueError(errmsg("Extra data", s, end, len(s)))
ValueError: Extra data: line 829 column 1 - line 829 column 2 (char 18476 - 18477)
[Finished in 0.1s with exit code 1]
896445 次浏览

json.load()方法(没有" "In "load")可以直接读取文件:

import json


with open('strings.json') as f:
d = json.load(f)
print(d)

您正在使用json.loads()方法,它仅用于字符串参数。


你得到的json.loads错误是一个完全不同的问题。在这种情况下,该文件中有一些无效的JSON内容。为此,我建议通过JSON验证器. xml文件运行该文件。

还有一些解决方案可以修复JSON,例如我如何自动修复一个无效的JSON字符串?< / >

这是一个代码的副本,对我来说很好,

import json


with open("test.json") as json_file:
json_data = json.load(json_file)
print(json_data)

用数据

{
"a": [1,3,"asdf",true],
"b": {
"Hello": "world"
}
}

你可能想要用试着抓住来包装你的json.load行,因为无效的JSON会导致一个堆栈跟踪错误消息。

问题是使用语句:

with open('strings.json') as json_data:
d = json.load(json_data)
pprint(d)

文件已经隐式关闭了。没有必要再次调用json_data.close()

在Python 3中,我们可以使用下面的方法。

从文件中读取并转换为JSON

import json
from pprint import pprint


# Considering "json_list.json" is a JSON file


with open('json_list.json') as fd:
json_data = json.load(fd)
pprint(json_data)

语句自动关闭打开的文件描述符。


字符串转换成JSON

import json
from pprint import pprint


json_data = json.loads('{"name" : "myName", "age":24}')
pprint(json_data)
为了补充这一点,今天你可以用熊猫来 导入JSON: pandas.read_json .read_json

您可能需要谨慎使用orient参数。

你可以使用熊猫库来读取JSON文件。

import pandas as pd
df = pd.read_json('strings.json', lines=True)
print(df)
def read_JSON():
with open("FILE PATH", "r") as i:
JSON_data = i.read()
print(JSON_data)