我有一个脚本,它调用下面的函数来从 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/