gpt4 book ai didi

python - 我的功能保存到 pickle 不工作

转载 作者:行者123 更新时间:2023-11-30 22:15:09 24 4
gpt4 key购买 nike

我有一个脚本,它调用下面的函数来从 pickle 加载创建一个字典,如下所示:

def load_obj(name ):
try:
with open('obj/' + name + '.pkl', 'rb') as f:
return pickle.load(f)
except:
return dict(name)

我更新 pickle 加载的字典以添加新的 key:value 记录,然后使用此函数保存 pickle:

def save_obj(obj, name ):
pathlib.Path('.obj').mkdir(exist_ok=True)
with open('.obj/'+ name + '.pkl', 'wb') as f:
pickle.dump(obj, f, pickle.HIGHEST_PROTOCOL)

我的目的是从 pickle 加载创建一个字典,向该字典添加一个新的 key:value 并保存 pickle。如果 key 已经在 pickle 加载的字典中,我就通过。我的问题是 save_obj 似乎没有将更新的字典保存到 pickle 中。我肯定错过了一些东西。任何帮助,将不胜感激。在我的测试中,我可以看到加载时字典的长度是1919,添加新记录后字典的长度是1920。

最佳答案

您正在正确添加和保存所有内容。但是,您没有以加载该文件的相同名称保存该文件。您加载文件 obj/test.pkl 并将其另存为 .obj/test.pkl。我的猜测是您尝试在此处使用当前目录符号,因此将每个 obj/.obj/ 更改为 ./obj/。还要检查文件系统中所有目录的名称和文件名。

关于python - 我的功能保存到 pickle 不工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50361764/

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