为什么在Python中使用池多处理会产生不同的结果?

2024-09-30 01:34:42 发布

您现在位置:Python中文网/ 问答频道 /正文

我有一个函数,它返回一个字典,其中包含名为的列表元素,如下所示:

lista =['GILDIKNK','MENIA']
dic={}

def nome_arquivos(lista_fragmentos):
    for elemento in lista_fragmentos:
        indice = "fragmento_" + str(lista_fragmentos.index(elemento)+1)
        dic[indice] = elemento
    print(dic)

nome_arquivos(lista)

在本例中,输出是(也是我想要的):

{'fragmento_1': 'GILDIKNK', 'fragmento_2': 'MENIA'}

然而,我正试图插入多处理,以解决更大的问题。这是我的代码:

from multiprocessing.pool import ThreadPool
import time

lista =['GILDIKNK','MENIA']
dic={}

def nome_arquivos(lista_fragmentos):
    for elemento in lista_fragmentos:
        indice = "fragmento_" + str(lista_fragmentos.index(elemento)+1)
        dic[indice] = elemento
    print(dic)

def pool_handler():
    pool = ThreadPool(4)
    results = pool.map(nome_arquivos, lista)


if __name__ == '__main__':
    pool_handler()

输出为:

{'fragmento_1': 'G', 'fragmento_2': 'I', 'fragmento_3': 'L', 'fragmento_4': 'D',
'fragmento_6': 'K', 'fragmento_7': 'N'}{'fragmento_1': 'M', 'fragmento_2': 'E',
'fragmento_3': 'N', 'fragmento_4': 'I', 'fragmento_6': 'K', 'fragmento_7': 'N',
'fragmento_5': 'A'}

我做错了什么


Tags: infordefpoolstrnomediclista
1条回答
网友
1楼 · 发布于 2024-09-30 01:34:42

关于为什么代码不工作,已经有一些很好的评论,所以我想我应该尝试重写您的第一个函数(没有任何多处理的函数)。它本身应该足够有效,如果需要多处理,我会感到惊讶

def proc_names(names_lst):
    return {f'fragmento_{idx}': curr_name for idx, curr_name in enumerate(names_lst, start=1)}

相关问题 更多 >

    热门问题