从文件中读取 JSON?

Posted

技术标签:

【中文标题】从文件中读取 JSON?【英文标题】:Reading JSON from a file? 【发布时间】:2013-12-10 12:52:30 【问题描述】:

我有点头疼,只是因为一个看起来很简单的陈述在我脸上抛出了一些错误。

我有一个名为 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.loads 更改为json.load

得到了这个:

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]

【问题讨论】:

您确定该文件包含有效的 JSON 吗? Parsing values from a JSON file in Python 的可能重复项 另见:Read & Write example for JSON 您的文件是无效的 json 格式。将其更改为:"strings": ["-name": "city", "#text": "City", "-name": "phone", "#text": "Phone", ..., "-name": "address", "#text": "Address"] 【参考方案1】:

json.load() method(“load”中不带“s”)可以直接读取文件:

import json

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

您使用的是json.loads() method,它仅用于字符串 参数。

编辑: 新消息是一个完全不同的问题。在这种情况下,该文件中有一些无效的 json。为此,我建议通过json validator 运行该文件。

还有修复 json 的解决方案,例如 How do I automatically fix an invalid JSON string?。

【讨论】:

hm...我从 json.loads 更改为 json.load 但我得到了很好的消息。 啊,新消息是一个完全不同的问题。在这种情况下,该文件中有一些无效的 json。为此,我建议通过json validator 运行该文件。 知道了!该文件缺少 EOF。文件未正确结束。如果这不是您的好建议,我不会注意到!谢谢! 我必须打开带有字节标志的文件,然后我才能使用 json.load 方法,为什么?我得到了 Py3.6 @GrzegorzKrug 不抱歉。但是json.loads() documentation 表示它接受文本或二进制文件,所以你应该这样做。【参考方案2】:

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

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"
    

你可能想用 try catch 包裹你的 json.load 行,因为无效的 JSON 会导致堆栈跟踪错误消息。

【讨论】:

【参考方案3】:

问题在于使用 with 语句:

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

该文件将被隐式关闭。无需再次拨打json_data.close()

【讨论】:

为了漂亮打印,我不得不使用:print(json.dumps(d,sort_keys=True,indent=2))【参考方案4】:

在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)

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


字符串转 JSON

import json
from pprint import pprint

json_data = json.loads('"name" : "myName", "age":24')
pprint(json_data)

【讨论】:

【参考方案5】:

补充一点,今天你可以使用 pandas 导入 json:https://pandas.pydata.org/pandas-docs/stable/generated/pandas.read_json.html 您可能需要谨慎使用 orient 参数。

【讨论】:

如果您添加代码示例以及网址,这个答案会更好......【参考方案6】:

您可以使用 pandas 库来读取 JSON 文件。

import pandas as pd
df = pd.read_json('strings.json',lines=True)
print(df)

【讨论】:

【参考方案7】:
def read_JSON():
    with open("FILE PATH", "r") as i:
        JSON_data = i.read()
    print(JSON_data)

【讨论】:

这一切只是打开 JSON 文件并将其读入一个变量,而不是解析它;你确定这是 OP 想要的吗? 是的,这将有助于读取 JSON 对象以将它们用作请求负载或用于任何其他目的。我将它用于我当前的 API 请求实现,它对我来说工作正常。 如果你必须解析文件,那么.read 将是一个不好的方法,因为你必须重新实现 json 模块已经做的事情。 我认为 LOAD 将使用 python 字典重新实现 JSON,但 READ 有助于将 JSON 直接加载到数据框

以上是关于从文件中读取 JSON?的主要内容,如果未能解决你的问题,请参考以下文章

Python问题:从一个文件夹中读取多个json文件只加载一个json

如何从 XCUITest 读取 Json 文件?

如何从 json 文件中读取数据,是不是有语法错误?

从文件中读取 JSON?

从 JSON 文件问题中读取国家名称

Datatables Ajax 在从文件中读取 JSON 时起作用,但从变量中读取 JSON 时不起作用(Django)