使用列表理解的列表字典

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] != '_'}

returns 仅出现字符的最后一个索引。

提前致谢!

在可能使用 mapfilter 的地方应该使用字典理解。您想要的 dict 是输入字符串的摘要。

您只需要退回到普通的 for 循环:

from collections import defaultdict

pattern = "abcdabccb"
summary = defaultdict(list)

for idx,c in enumerate(pattern):
    summary[c].append(idx)

按需输出

这是个有趣的问题。您需要在字典理解中进行列表理解:

>>> 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作为key,让对应的值为p中此类索引i的列表,其中p[i] == c.

而不是 for c in p,您可以使用 for c in set(p) 只对每个字符迭代一次。

正如@quamrana 指出的那样,您始终可以使用循环。在这里,循环会更具可读性。但是为了磨练你的听写理解能力,这是一个很好的练习题。