【发布时间】:2014-09-16 20:34:37
【问题描述】:
每个人。我正在使用 Networkx 1.9 模块在 Python 2.7 中编写一个简单的函数,以测试我的图形分区算法实现是否正常工作。为此,我有一个列表 dvecs,它为列表分区中的每个块提供一个列表,该列表提供有关从每个节点到分区中的类的边的信息。看一眼:
#dvecs : list of len(P) lists which correspond to a list of degree vectors of each block
numBlocks = len(P)
dvecs = [[]] * numBlocks
for block in P:
blockNo = P.index(block)
dvecs[blockNo] = [[-1] * numBlocks] * len(block)
for node in block:
nodeNo = block.index(node)
for otherBlock in P:
otherBlockNo = P.index(otherBlock)
dvecs[blockNo][nodeNo][otherBlockNo] = len(set(nx.neighbors(G, node)).intersection(set(otherBlock)))
我遇到的问题是,在嵌套循环的最后一行,以 dvec[blockNo...] 开头的行,根据调试器,中间深度列表中的每个条目(对于最内层循环的每次迭代,具有由 nodeNo 指定的索引的索引都被更新为相同的值。换句话说,就好像 'node' 保持不变,并且 nodeNo 遍历块中的所有节点。这是怎么回事?
为了回应罗曼,我尝试了以下方法:
for blockNo, block in enumerate(P):
dvecs[blockNo] = [[-1] * numBlocks] * len(block)
for nodeNo, node in enumerate(block):
for otherBlockNo, otherBlock in enumerate(P):
dvecs[blockNo][nodeNo][otherBlockNo] = len(set(nx.neighbors(G, node)).intersection(set(otherBlock)))
但是,我得到了相同的行为。我错过了什么?
【问题讨论】:
-
注意使用枚举而不是获取 ex:stackoverflow.com/questions/1185545/… 的索引
-
感谢 Roman,您的快速回复。我对 python 很陌生,所以直到现在我才听说过。
-
如果您是新手,您可能还想了解有关清理文件/其他资源的语句:stackoverflow.com/questions/3012488/…
-
酷,谢谢。不确定它是否会通知您对我的初始帖子的编辑(我也是 SO 新手),但我尝试使用 enumerate 但我遇到了同样的问题。你能看看我贴的代码吗?