[英]Dictionary of lists using list comprehension
我有一个字符串(我将其视为一个字符列表),我正在尝试通过字典理解来创建一个字典,其中包含字符串中每个字符的键以及作为它出现的索引列表的值。
例如:
pattern = "abcdabccb"
所需词典:
{'a' : [0,4], 'b' : [1,5,8], 'c':[2,6,7], 'd':[3]}
迄今为止最好的尝试:
{pattern[i]: [i] for i in range(0, len(pattern)) if pattern[i] != '_'}
仅返回字符出现的最后一个索引。
提前致谢!
这是一个有趣的问题。 您需要在字典理解中进行列表理解:
>>> p = "abcdabccb"; # pattern
>>> {c: [i for i in range(len(p)) if p[i] == c] for c in p}
{'a': [0, 4], 'b': [1, 5, 8], 'c': [2, 6, 7], 'd': [3]}
>>>
简而言之,这就是理解所说的:
通过迭代模式p
中的每个字符c
来组成字典。 使用每个c
作为键,并让相应的值成为p
中此类索引i
的列表,其中p[i] == c
。
您可以for c in set(p)
而不是for c in p
中的 for c 来迭代每个字符一次。
正如@quamrana 指出的那样,您始终可以使用循环。 在这里,循环会更具可读性。 但是为了磨练你的听写理解能力,这是一个很好的练习题。
在可能使用map
或filter
的地方应该使用字典理解。 您想要的dict
是输入字符串的摘要。
你只需要回到一个普通的 for 循环:
from collections import defaultdict
pattern = "abcdabccb"
summary = defaultdict(list)
for idx,c in enumerate(pattern):
summary[c].append(idx)
Output 根据需要
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.