if __和__ in ___ then
我正在尝试创建一个循环遍历列表的脚本。
我需要查看能力标识符的有限列表(400)(例如124,129等 - 正常的整数)
然后我有一本字典记录了每个用户的能力。密钥是用户名,每个密钥的值是整数列表(即用户具有哪些能力)
例如
User x - [124, 198, 2244 ...]
User Y - [129, 254, 198, 2244 ...]
我希望编制一个矩阵,突出显示每个能力与其他所有能力一起出现的频率 - 邻接矩阵。
例如,在以上示例中,能力198已经两次出现,具有能力2244。而能力254和124从未一起发生过。
我目前正在使用此代码:
fe = []
count = 0
competency_matches = 0
for comp in competencies_list:
common_competencies = str("")
for comp2 in competencies_list:
matches = int(0)
for person in listx:
if comp and comp2 in d1[person]:
matches = matches + 1
else:
matches = matches
common_competencies = str(common_competencies) + str(matches) + ","
fe.append(common_competencies)
print fe
print count
count = count + 1
这不起作用,只返回每个能力总体发生的次数。我认为问题在于“如果comp和comp2在d1 [person]:”行中。
问题是,例如,如果一个人具有以下能力[123,1299,1236]并且我搜索了能力123,则由于出现在123和1236条目中,这将被返回两次。在使用if __和__ then操作时,是否存在强制完全匹配的方法。
或者有没有人有一个改进的建议如何实现这一目标......
提前感谢任何指针。干杯
没有找到相关结果
已邀请:
3 个回复
骂陋冠
的工作原理。要测试列表中是否有两个值,请使用:
你的版本做了别的事。它绑定如下:
。换句话说,它将
解释为真值,然后使用列表包含检查进行布尔值
。这是有效的代码,但它不能做你想要的。
系漏
结果是
......显然,一个400柱的桌子有点印刷到屏幕上;我建议使用csv.writer()将其保存到一个文件,然后您可以在Excel或OpenOffice中使用它。
抚驰
并将
设置为空字符串400次,然后再次遍历
并执行phooji解释的内容。我很确定这不是你想要做的。