我在Python代码中有一个这样的字典:
S = {(x0): 'omicron', (x1): 'a', (x2): 'ab', (x3): 'abbr', (x4): 'abr', (x5): 'abrf', (x6): 'abrfa', (x7): 'af', '(x8)': 'afc'}
我想检查哪个键对应的字典中有最多的字母,除了包含"omicron"的那个键。这个例子中的答案应该是:(x6),因为它有一个包含5个字母的字典,比任何其他键都多,而且不包括(x0):'omicron'。
是否有有效的方法来做到这一点?谢谢你。
您可以使用max的关键参数:
res = max(S, key=lambda x: (S[x] != 'omicron', len(S[x])))
print(res)
(x6)
这将使值不同于'omicron'
的键值大于等于(1>0).对于那些没有'omicron'
值的键,使用长度作为断点
S = {('x0'): 'omicron', ('x1'): 'a', ('x2'): 'ab', ('x3'): 'abbr', ('x4'): 'abr', ('x5'): 'abrf', ('x6'): 'abrfa', ('x7'): 'af', ('x8'): 'afc'}
keys = list(S.keys())
longest = 0
word = ''
for i in range(len(keys)):
if len(S[f'{keys[i]}']) > longest and S[f'{keys[i]}'] != 'omicron':
longest = len(S[f'{keys[i]}'])
word = keys[i]
print(longest, word)
输出:
5 x6