小编典典

如何将数据附加到json文件?

json

我正在尝试创建一个将条目添加到json文件的函数。最终,我想要一个看起来像

[{"name" = "name1", "url" = "url1"}, {"name" = "name2", "url" = "url2"}]

等。这就是我所拥有的:

def add(args):
    with open(DATA_FILENAME, mode='r', encoding='utf-8') as feedsjson:
        feeds = json.load(feedsjson)
    with open(DATA_FILENAME, mode='w', encoding='utf-8') as feedsjson:
        entry = {}
        entry['name'] = args.name
        entry['url'] = args.url
        json.dump(entry, feedsjson)

这确实会创建一个条目,例如{"name"="some name", "url"="some url"}。但是,如果我add再次使用此函数(使用不同的名称和网址),第一个函数将被覆盖。我需要怎么做才能将第二个(第三个…)条目附加到第一个?

编辑 :对此问题的第一个答案和评论已经指出了我feeds在写块中未使用的明显事实。不过,我看不出该怎么做。例如,以下内容显然不会起作用:

with open(DATA_FILENAME, mode='a+', encoding='utf-8') as feedsjson:
    feeds = json.load(feedsjson)
    entry = {}
    entry['name'] = args.name
    entry['url'] = args.url
    json.dump(entry, feeds)

阅读 291

收藏
2020-07-27

共1个答案

小编典典

json可能不是磁盘格式的最佳选择。附加数据带来的麻烦就是一个很好的例子。具体来说,json对象具有一种语法,这意味着必须阅读并解析整个对象才能理解其中的任何部分。

幸运的是,还有很多其他选择。CSV特别简单。python的标准库很好地支持了这一点。最大的缺点是,它仅适用于文本。如果需要,程序员需要采取其他措施才能将值转换为数字或其他格式。

没有此限制的另一个选项是使用sqlite数据库,该数据库在python中也具有内置支持。这可能与您已经拥有的代码有更大的不同,但是它自然而然地支持您显然试图构建的“稍微修改”模型。

2020-07-27