gpt4 book ai didi

python - 在 Python 中序列化用户定义的类

转载 作者:太空宇宙 更新时间:2023-11-03 14:34:28 24 4
gpt4 key购买 nike

有一个关于序列化我定义的类的问题。我有一些类

class Foo:
def __init__(self, x, y):
self.x = x, self.y = y

def toDict(self):
return dict(Foo = dict(x = self.x, y = self.y))

然后是一个可以包含多个Foos的类,比如:

class Bar:
def __init__(self):
self.foos = [Foo(a, b), Foo(1, 2)]

虽然这是对真实结构的粗略过度简化(它的嵌套比这要多得多),但这是一个相当不错的概述。这个的实际数据来自一个没有任何实际结构的伪 XML 文件,所以我根据给我的规范编写了一个解析器,所以我现在拥有我定义的一系列类中的所有数据,具有实际结构。

我想做的是获取我拥有的这些数据并将其输出到 JSON 中,但我真的没有看到一个好的方法(我是 Python 的新手,这是我的第一个真正的项目) .

我在 Foo 中定义了一个方法,toDict(),它根据信息创建一个字典,但是当我尝试使用多个 Foos 序列化 Bar 时,这显然不会像我希望的那样工作。

有没有人有一个很好的方法来做到这一点?在过去的几天里,这几乎是一个不间断的学习/代码节,我对此一无所知,这是该项目的最后一部分。我知道 Python 的 JSON 模块,但这并不能帮助我解决将我的数据放入我可以传递给 json.dump() 的字典(或类似的东西)这个特殊问题。

如果我能以任何方式澄清,请告诉我。

谢谢,T.J.

最佳答案

几条评论。第一:

  • xml.dom.minidom是一个内置的 Python DOM 实现。显然,如果该文件实际上不是 XML,您将无法使用它的内置解析函数,但看起来您正在从文件中构建树状结构,在这种情况下,您不妨使用迷你王国

好的,从今以后我假设您有充分的理由编写自己的树型结构而不是使用内置函数。

  • 你确定节点应该是类吗?当您真正需要的只是一堆嵌套的 dict 时,这似乎是一个非常多的结构:

    root = {
    "foo1": { "bar1": "spam", "bar2": "ham"},
    "foo2": { "baz1": "spam", "baz2": "ham"},
    }

    你明白了。

好的,也许您确定需要将各个节点作为类。在那种情况下,它们应该都继承自某个 BaseNode 类,对吧?毕竟,它们在本质上是相似的。

  • 在那种情况下,定义一个 BaseNode.serialise 方法,它有效地打印一些关于它自己的信息,然后在它的所有子节点上调用 serialise。这是一个递归问题;您不妨使用递归解决方案,除非您的树确实真的嵌套。

    json 库允许您继承 JSONEncoder 来执行此操作。

    >>> import json
    >>> class ComplexEncoder(json.JSONEncoder):
    ... def default(self, obj):
    ... if isinstance(obj, complex):
    ... return [obj.real, obj.imag]
    ... return json.JSONEncoder.default(self, obj)
    ...
    >>> dumps(2 + 1j, cls=ComplexEncoder)
    '[2.0, 1.0]'
    >>> ComplexEncoder().encode(2 + 1j)
    '[2.0, 1.0]'
    >>> list(ComplexEncoder().iterencode(2 + 1j))
    ['[', '2.0', ', ', '1.0', ']']

关于python - 在 Python 中序列化用户定义的类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4089000/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com