使用地图,池和管理器 - python

我有一个list包含tuples作为元素。列表如下所示:
elements = [('a', 'b'), ('c', 'd'), ...]

我要在此列表上执行一些操作。但是此列表中的元素数量很大。因此,我想进行多处理。同样,最终结果应存储在另一个列表中。但是我无法弄清楚如何传递参数。这是我的示例代码:

class DoSomething:
    def __init__(self):
        pass
    def __call__(self, pair, final_list):
        y = " ".join(pair)
        if y in ["a b c", " b c", "a c"]:
            final_list+=y

pairs = [('a', 'b'), ('a', 'c'), ('b', 'c'), ('b', 'd')]
ds = DoSomething()
p =  Pool()

with Manager() as manager:
    final_list = manager.list()
    p.map(ds(..)) # I don't know how to call this now

现在如何将final_list传递给ds

参考方案

我认为您不需要将final_list传递给可调用对象,只需在类内部声明final_list甚至在__init__内部声明更好。

from multiprocessing import Pool, Manager


class DoSomething:
    m = Manager()
    final_list = m.list()
    def __init__(self):
    # m = Manager()
    # self.final_list = m.list()
        pass
    def __call__(self, pair):
        y = " ".join(pair)
        if y not in ["a b c", " b c", "a c"]:
            self.final_list.append(y)

pairs = [('a', 'b'), ('a', 'c'), ('b', 'c'), ('b', 'd')]
ds = DoSomething()
p =  Pool()

p.map(ds, pairs)

print(ds.final_list)

或者您也可以使用starmap传递多个参数,如下所示

l = list(zip_longest(l, pairs))
p.starmap(ds, l)

R'relaimpo'软件包的Python端口 - python

我需要计算Lindeman-Merenda-Gold(LMG)分数,以进行回归分析。我发现R语言的relaimpo包下有该文件。不幸的是,我对R没有任何经验。我检查了互联网,但找不到。这个程序包有python端口吗?如果不存在,是否可以通过python使用该包? python参考方案 最近,我遇到了pingouin库。

如何用'-'解析字符串到节点js本地脚本? - python

我正在使用本地节点js脚本来处理字符串。我陷入了将'-'字符串解析为本地节点js脚本的问题。render.js:#! /usr/bin/env -S node -r esm let argv = require('yargs') .usage('$0 [string]') .argv; console.log(argv…

用大写字母拆分字符串,但忽略AAA Python Regex - python

我的正则表达式:vendor = "MyNameIsJoe. I'mWorkerInAAAinc." ven = re.split(r'(?<=[a-z])[A-Z]|[A-Z](?=[a-z])', vendor) 以大写字母分割字符串,例如:'我的名字是乔。 I'mWorkerInAAAinc”变成…

Python:传递记录器是个好主意吗? - python

我的Web服务器的API日志如下:started started succeeded failed 那是同时收到的两个请求。很难说哪一个成功或失败。为了彼此分离请求,我为每个请求创建了一个随机数,并将其用作记录器的名称logger = logging.getLogger(random_number) 日志变成[111] started [222] start…

Python-Excel导出 - python

我有以下代码:import pandas as pd import requests from bs4 import BeautifulSoup res = requests.get("https://www.bankier.pl/gielda/notowania/akcje") soup = BeautifulSoup(res.cont…