ChatGPT解决这个技术问题 Extra ChatGPT

使用 Python 将 JSON 字符串转换为 dict [重复]

这个问题在这里已经有了答案:How to parse data in JSON format (4 answers) 上个月关闭。

我对 Python 中的 JSON 有点困惑。对我来说,它就像一本字典,因此我正在尝试这样做:

{
    "glossary":
    {
        "title": "example glossary",
        "GlossDiv":
        {
            "title": "S",
            "GlossList":
            {
                "GlossEntry":
                {
                    "ID": "SGML",
                    "SortAs": "SGML",
                    "GlossTerm": "Standard Generalized Markup Language",
                    "Acronym": "SGML",
                    "Abbrev": "ISO 8879:1986",
                    "GlossDef":
                    {
                        "para": "A meta-markup language, used to create markup languages such as DocBook.",
                        "GlossSeeAlso": ["GML", "XML"]
                    },
                    "GlossSee": "markup"
                }
            }
        }
    }
}

但是当我做 print dict(json) 时,它给出了一个错误。

如何将此字符串转换为结构,然后调用 json["title"] 以获得“示例词汇表”?


D
David Leon

json.loads()

import json

d = json.loads(j)
print d['glossary']['title']

json.load 和 json.loads 有什么区别?
@ShivamAgrawal:正是它所说的on the tin
@ShivamAgrawal:区别在于 .load() 解析文件对象; .loads() 解析字符串/unicode 对象。
困扰我的是,这个函数的作者没有编写一个包装函数来对传入的数据进行类型检查以自动选择要调用的正确函数。我也不喜欢使用模糊的命名法。以下是我为解决这个问题而写的:def read_json(json_data): if (type(json_data) == str): return json.loads(json_data) elif (str(type(json_data)) == "<class '_io.TextIOWrapper'>"): return json.load(json_data) 我确信这可以改进,但现在您可以在 json 'str' 或 'file' 上调用 d = read_json(j)
@JacquesMathieu,嗨 Jacques,thanx 为你的功能,我做了一个小的改进,因为我有时使用字典: def read_json(json_data): if (type(json_data) == str): # For strings return json.loads(json_data) elif (str(type(json_data)) == ""): #对于文件返回 json.load(json_data) elif (type(json_data) == dict): # 对于字典返回 json.loads (json.dumps(json_data))
H
Hussain

刚开始用json的时候,一时糊涂,搞不明白,终于得到了我想要的 这里是简单的解决

import json
m = {'id': 2, 'name': 'hussain'}
n = json.dumps(m)
o = json.loads(n)
print(o['id'], o['name'])

为什么你首先转储(m)?
我用它来演示序列化和反序列化。在 '{"id": 2, "name": "hussain"}' 上使用 loads(..) 也应该像接受的答案一样好。
转储和加载对我来说是完美的,而接受的答案不是,非常感谢@Hussain 为我保存了一个time,仅供参考,我正在尝试从具有 utf-8 编码的动态字符串中loads ...
k
kakhkAtion

如果您信任数据源,则可以使用 eval 将您的字符串转换为字典:

eval(your_json_format_string)

例子:

>>> x = "{'a' : 1, 'b' : True, 'c' : 'C'}"
>>> y = eval(x)

>>> print x
{'a' : 1, 'b' : True, 'c' : 'C'}
>>> print y
{'a': 1, 'c': 'C', 'b': True}

>>> print type(x), type(y)
<type 'str'> <type 'dict'>

>>> print y['a'], type(y['a'])
1 <type 'int'>

>>> print y['a'], type(y['b'])
1 <type 'bool'>

>>> print y['a'], type(y['c'])
1 <type 'str'>

您示例中的字符串不是 JSON。
真的。它评估为一个字典,它可以很容易地作为 JSON 加载/转储(当然,如果你的字典没有 json 值,你可能需要一个自定义的 json 编码器函数)。
不,您永远不应该将输入数据作为代码进行评估。这可能是您的小宠物项目,它使用您信任的数据,但在实际项目中可以重复使用不良代码和重复不良做法,从而留下大量安全代码。
这就是为什么我的回答以“如果您信任数据源”开头!但确实,这更像是一种 hack,绝对不是最佳实践。
如果数据源是您自己的,您可以完全信任它。这对于将字符串化的 JS 对象转换为 dic 到正确的 JSON 字符串实际上很有用。
j
jassinm

使用 simplejson 或 cjson 来加速

import simplejson as json

json.loads(obj)

or 

cjson.decode(obj)