首頁 後端開發 Python教學 為什麼 Python 多重處理會失敗並出現「PicklingError: Can't pickle」以及如何修復它?

為什麼 Python 多重處理會失敗並出現「PicklingError: Can't pickle」以及如何修復它?

Dec 08, 2024 pm 08:33 PM

Why Does Python Multiprocessing Fail with

「PicklingError:無法pickle 」故障排除在Python Multiprocessing

當嘗試使用Python的多處理模組時,你可能會遇到“PicklingError: Can't pickle ”錯誤。當嘗試 pickle 未在模組頂層定義的函數時,通常會發生這種情況。

理解 Pickling

Pickling 是將物件轉換為物件的流程二進位流,允許儲存並稍後重新建立。在多重處理中,任務透過佇列在網路上傳輸,因此它們必須是可挑選的。

函數和頂層定義

在頂層定義的常規函數模組本質上是可醃製的。但是,在類別或其他巢狀函數中定義的函數則不然。這是因為在 pickling 過程中遇到的「全域變數」可能與創建它們的過程中的不同。

不可Picklable 函數的範例

考慮以下程式碼定義了巢狀在類別方法中的函數:

class Foo:
    def g(self):
        def h():
            pass
        h()
登入後複製

呼叫pool.apply_async (Foo().g) 將導致“PicklingError”,因為巢狀函數h 未在頂層定義。

解決方案

至解決這個問題,只需在模組的頂層定義函數並從嵌套函數中調用它即可。例如:

def g(foo):
    def h():
        pass
    h()
    foo.work()
登入後複製

現在,pool.apply_async(g, args=(Foo(),)) 會正常運作。

以上是為什麼 Python 多重處理會失敗並出現「PicklingError: Can't pickle」以及如何修復它?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱門文章

倉庫:如何復興隊友
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章

倉庫:如何復興隊友
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章標籤

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

我如何使用美麗的湯來解析HTML? 我如何使用美麗的湯來解析HTML? Mar 10, 2025 pm 06:54 PM

我如何使用美麗的湯來解析HTML?

python中的圖像過濾 python中的圖像過濾 Mar 03, 2025 am 09:44 AM

python中的圖像過濾

如何使用Python查找文本文件的ZIPF分佈 如何使用Python查找文本文件的ZIPF分佈 Mar 05, 2025 am 09:58 AM

如何使用Python查找文本文件的ZIPF分佈

如何使用Python使用PDF文檔 如何使用Python使用PDF文檔 Mar 02, 2025 am 09:54 AM

如何使用Python使用PDF文檔

如何在django應用程序中使用redis緩存 如何在django應用程序中使用redis緩存 Mar 02, 2025 am 10:10 AM

如何在django應用程序中使用redis緩存

如何使用TensorFlow或Pytorch進行深度學習? 如何使用TensorFlow或Pytorch進行深度學習? Mar 10, 2025 pm 06:52 PM

如何使用TensorFlow或Pytorch進行深度學習?

如何在Python中實現自己的數據結構 如何在Python中實現自己的數據結構 Mar 03, 2025 am 09:28 AM

如何在Python中實現自己的數據結構

python對象的序列化和避難所化:第1部分 python對象的序列化和避難所化:第1部分 Mar 08, 2025 am 09:39 AM

python對象的序列化和避難所化:第1部分

See all articles