我在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'值的键,使用长度作为tie-breaker。
###
S = {('x0'): 'omicron', ('x1'): 'a', ('x2'): 'ab', ('x3'): 'abbr', ('x4'): 'abr', ('x5'): 'abrf', ('x6'): 'abrfa', ('x7'): 'af', ('x8'): 'afc'}
键=列表(S。keys ())
最长= 0
词= "
For I in range(len(keys)):
如果len (S [f '{键[我]}'])的在S[f'{keys[i]}'] != 'omicron':
最长= len (S [f '{键[我]}'])
词=键[我]
打印(最长单词)
输出:
5 x6