使用列表理解的列表字典
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 仅出现字符的最后一个索引。
提前致谢!
在可能使用 map
或 filter
的地方应该使用字典理解。您想要的 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 指出的那样,您始终可以使用循环。在这里,循环会更具可读性。但是为了磨练你的听写理解能力,这是一个很好的练习题。
我有一个字符串(我将其视为一个字符列表),我正在尝试通过字典理解来创建一个字典,其中包含字符串中每个字符的键以及作为索引列表的值它出现了。
例如:
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 仅出现字符的最后一个索引。
提前致谢!
在可能使用 map
或 filter
的地方应该使用字典理解。您想要的 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 指出的那样,您始终可以使用循环。在这里,循环会更具可读性。但是为了磨练你的听写理解能力,这是一个很好的练习题。