所以我已经提取了html的源代码并将所有内容转换成了一个大词典。
这只是一个例子:
d = {fist:mist}
我的目标是通过索引比较字符:
(key[0] & value[0], key[1] & value[1], etc.)
并检查字符是否相等:
f != m, i == i, s==s, t==t
我能做的最好:
d = {fist:mist}
difference = 0
no_difference = 0
for key, value in d.items():
for char1 in key:
pass
for char2 in value:
pass
if char1 != char2:
difference += 1
if char1 == char2:
no_difference +=1
print(difference)
print(no_difference)
我感谢任何帮助。
编辑:非常感谢Glenn Codes,Joe Iddon和MikeMüller!
答案 0 :(得分:3)
您需要遍历字典中的key : value
对。对于每对,您需要确定key
和value
之间存在多少差异。这可以通过计算仅包含不同字符的list
的长度来完成。
然后我们将这个长度添加到循环外的变量中以跟踪总数。
d = {"fist":"mist"}
differences = 0
for k, v in d.items():
differences += len([i for i,c in enumerate(k) if c != v[i]])
print(differences)
,对于此处的小示例,1
提供'f'
,'m'
不同。
如果您还想要匹配(即没有不同)的字符数,那么您可以执行相同的过程,但添加key
的长度减去差异以获得字符数这是相同的:
d = {"fist":"mist"}
differences = 0
same = 0
for k, v in d.items():
differences += len([i for i,c in enumerate(k) if c != v[i]])
same += len(k) - differences
print(differences)
print(same)
再次将differences
作为1
,同时将same
作为3
('i'
,'s'
和{{1} })。
如果你只想要一个布尔('t'
)值来确定任何对之间是否有任何差异,你可以在一行中完成整个操作:
True / False
在这种情况下给出all(k == v for k,v in d.items())
。
答案 1 :(得分:1)
假设键和值的长度相同:
for key, value in d.items():
for i in range(len(key)):
if key[i] == value[i]:
no_difference +=1
else:
difference += 1
答案 2 :(得分:1)
假设一个包含多个项目以及可能的不同长度的键和值的字典,这应该有效:
a
输出:
from itertools import zip_longest
d = {'fist': 'mist', 'fist1': 'mist22', 'x': 'many differences here'}
difference = 0
no_difference = 0
for k, v in d.items():
for item1, item2 in zip_longest(k, v, fillvalue=''):
if item1 == item2:
no_difference += 1
else:
difference += 1
print('difference:', difference)
print('no_difference:', no_difference)