所以我有这段代码:
def someFunction (S):
pass
if __name__ == "__main__":
import time
start = time.time()
G = nx.read_gpickle("../../graphs/graph.gpickle")
Ep = dict()
with open("Ep.txt") as f:
for line in f:
data = line.split()
Ep[(int(data[0]), int(data[1]))] = float(data[2])
pool = None
def mapAvgSize (S):
return avgIAC(G, S, Ep, I)
if pool == None:
pool = multiprocessing.Pool(processes=4)
print 'Start Initialization...'
S = []
print 'Selecting S...'
print 'before pool.map'
Ts = pool.map(mapAvgSize, [S]*4)
print 'after pool.map'
看起来一切都是正确的:我在池之前定义了函数,将所有内容都放在 if __name__ == "__main__": 语句下。但不幸的是,上面的代码执行到 print 'before pool.map' 行,然后抛出错误:
AttributeError: 'module' object has no attribute 'mapAvgSize'
最奇怪的是,上面的代码在 Linux 下工作,但在 Windows 上失败(我想在我的笔记本电脑外在具有更多内核的计算机上测试它)。
任何有助于弄清楚为什么代码在 Windows 上失败的帮助都将受到赞赏和支持。
最佳答案
如前所述,您需要使 mapAvg 成为顶级函数。由于它目前关闭了一些“本地”变量,因此您也需要修复此问题。您可以使用初始化器(mapped + initializer 在示例中)传递那些当前关闭的变量,或者将它们传递给您正在映射的迭代器(mapped2 )
示例,展示(部分)您的选择:
import multiprocessing
globalB = None
def mapped(a):
global globalB
return a * globalB
def initializer(*args):
global globalB
globalB, = args
def mapped2(args):
a, b = args
return a * b
if __name__ == "__main__":
myB = 2
pool = multiprocessing.Pool(processes=5,
initializer=initializer,
initargs=(myB,)
)
# Using the initializer provided globalB
for i in pool.map(mapped, range(10)):
print i
# directly provided as an arg
for i in pool.map(mapped2, ((a, myB) for a in range(10))):
print i
在您的代码中,您当然可以将 Ep、G(以及任何 I)移动到顶层,但是你会导致每个池进程的文件 I/O,所以如果我必须实现它,我会正确地使用类似 mapped2 的东西(使用专用的队列项类而不是一些元组)。
PS:这甚至可以在 Linux 上运行(有时?!)的原因似乎是 fork() 工作方式的意外结果。你不应该依赖它。
关于python - Windows 中 pool.map 的属性错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24679740/
我需要在客户计算机上运行Ruby应用程序。通常需要几天才能完成(复制大备份文件)。问题是如果启用sleep,它会中断应用程序。否则,计算机将持续运行数周,直到我下次访问为止。有什么方法可以防止执行期间休眠并让Windows在执行后休眠吗?欢迎任何疯狂的想法;-) 最佳答案 Here建议使用SetThreadExecutionStateWinAPI函数,使应用程序能够通知系统它正在使用中,从而防止系统在应用程序运行时进入休眠状态或关闭显示。像这样的东西:require'Win32API'ES_AWAYMODE_REQUIRED=0x0
关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。
大约一年前,我决定确保每个包含非唯一文本的Flash通知都将从模块中的方法中获取文本。我这样做的最初原因是为了避免一遍又一遍地输入相同的字符串。如果我想更改措辞,我可以在一个地方轻松完成,而且一遍又一遍地重复同一件事而出现拼写错误的可能性也会降低。我最终得到的是这样的:moduleMessagesdefformat_error_messages(errors)errors.map{|attribute,message|"Error:#{attribute.to_s.titleize}#{message}."}enddeferror_message_could_not_find(obje
我希望我的UserPrice模型的属性在它们为空或不验证数值时默认为0。这些属性是tax_rate、shipping_cost和price。classCreateUserPrices8,:scale=>2t.decimal:tax_rate,:precision=>8,:scale=>2t.decimal:shipping_cost,:precision=>8,:scale=>2endendend起初,我将所有3列的:default=>0放在表格中,但我不想要这样,因为它已经填充了字段,我想使用占位符。这是我的UserPrice模型:classUserPrice回答before_val
我有一个包含模块的模型。我想在模块中覆盖模型的访问器方法。例如:classBlah这显然行不通。有什么想法可以实现吗? 最佳答案 您的代码看起来是正确的。我们正在毫无困难地使用这个确切的模式。如果我没记错的话,Rails使用#method_missing作为属性setter,因此您的模块将优先,阻止ActiveRecord的setter。如果您正在使用ActiveSupport::Concern(参见thisblogpost),那么您的实例方法需要进入一个特殊的模块:classBlah
我有一个具有一些属性的模型:attr1、attr2和attr3。我需要在不执行回调和验证的情况下更新此属性。我找到了update_column方法,但我想同时更新三个属性。我需要这样的东西:update_columns({attr1:val1,attr2:val2,attr3:val3})代替update_column(attr1,val1)update_column(attr2,val2)update_column(attr3,val3) 最佳答案 您可以使用update_columns(attr1:val1,attr2:val2
我遵循MichaelHartl的“RubyonRails教程:学习Web开发”,并创建了检查用户名和电子邮件长度有效性的测试(名称最多50个字符,电子邮件最多255个字符)。test/helpers/application_helper_test.rb的内容是:require'test_helper'classApplicationHelperTest在运行bundleexecraketest时,所有测试都通过了,但我看到以下消息在最后被标记为错误:ERROR["test_full_title_helper",ApplicationHelperTest,1.820016791]test
我有这个html标记:我想得到这个:我如何使用Nokogiri做到这一点? 最佳答案 require'nokogiri'doc=Nokogiri::HTML('')您可以通过xpath删除所有属性:doc.xpath('//@*').remove或者,如果您需要做一些更复杂的事情,有时使用以下方法遍历所有元素会更容易:doc.traversedo|node|node.keys.eachdo|attribute|node.deleteattributeendend 关于ruby-Nokog
对于Rails模型,是否可以/建议让一个类的成员不持久保存到数据库中?我想将用户最后选择的类型存储在session变量中。由于我无法从我的模型中设置session变量,我想将值存储在一个“虚拟”类成员中,该成员只是将值传递回Controller。你能有这样的类(class)成员吗? 最佳答案 将非持久属性添加到Rails模型就像任何其他Ruby类一样:classUser扩展解释:在Ruby中,所有实例变量都是私有(private)的,不需要在赋值前定义。attr_accessor创建一个setter和getter方法:classUs
我是rails的新手,想在form字段上应用验证。myviewsnew.html.erb.....模拟.rbclassSimulation{:in=>1..25,:message=>'Therowmustbebetween1and25'}end模拟Controller.rbclassSimulationsController我想检查模型类中row字段的整数范围,如果不在范围内则返回错误信息。我可以检查上面代码的范围,但无法返回错误消息提前致谢 最佳答案 关键是您使用的是模型表单,一种显示ActiveRecord模型实例属性的表单。c