簡體   English   中英

參考在Python中被酸洗弄亂了

[英]Reference messed up by pickling in Python

我在python中引用了同一列表

x = y = []

然后,我用pickle.dump將它們腌制到一個文本文件中,但是當我再次用pickle.load加載它們時,它們變成了兩個具有不同內存地址的不同列表。 如何在酸洗過程中保持參照關系?

如果將xy腌制為兩個單獨的列表,則無論您是否預先腌制它們,它們在共享時都不會共享引用。 腌制對象而不是引用

>>> import pickle
>>> x = y = [1, 2]
>>> with open('test.txt', 'w') as f:
    pickle.dump(x, f)
    pickle.dump(y, f)


>>> with open('test.txt') as f:
    x = pickle.load(f)
    y = pickle.load(f)


>>> x == y
True
>>> x is y
False

如果您希望兩個名稱在重新load后共享引用,則可以對一個容器進行pickle

>>> x = y = [1, 2]
>>> with open('text.txt', 'w') as f:
    pickle.dump([x, y], f)


>>> with open('text.txt') as f:
    x, y = pickle.load(f)


>>> x == y
True
>>> x is y
True

但是您不妨腌制一份清單!

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM