sentence = "The quick brown fox jumped over the lazy dog."
characters = {}
for character in sentence:
characters[character] = characters.get(character, 0) + 1
print(characters)
我不明白characters.get(character, 0) + 1
在做什么,rest看起来很简单。
发布于 2010-01-15 07:41:23
字典的get
方法(例如characters
)的工作原理与索引字典类似,不同之处在于,如果缺少键,它将返回默认值,而不是引发KeyError
(如果只使用一个参数调用.get
,则默认值为None
)。
所以一个等价的Python函数(其中调用myget(d, k, v)
就像d.get(k, v)
可能是:
def myget(d, k, v=None):
try: return d[k]
except KeyError: return v
问题中的示例代码显然是在尝试计算每个字符的出现次数:如果已经有一个给定字符的计数,则get
返回该计数(因此它只是递增1),否则get
返回0(因此递增正确地给出了字符在字符串中第一次出现时的1
)。
发布于 2010-01-15 07:52:32
如果d是一个字典,那么d.get(k, v)
的意思是,给我d中k的值,除非k不在那里,在这种情况下给我v。它在这里用来获得字符的当前计数,如果以前没有遇到过字符,应该从0开始。
发布于 2014-01-28 00:35:50
我知道这是一个相当古老的问题,但这看起来像是在没有语言特性知识的情况下编写的东西。collections
库就是为了实现这些目的而存在的。
from collections import Counter
letter_counter = Counter()
for letter in 'The quick brown fox jumps over the lazy dog':
letter_counter[letter] += 1
>>> letter_counter
Counter({' ': 8, 'o': 4, 'e': 3, 'h': 2, 'r': 2, 'u': 2, 'T': 1, 'a': 1, 'c': 1, 'b': 1, 'd': 1, 'g': 1, 'f': 1, 'i': 1, 'k': 1, 'j': 1, 'm': 1, 'l': 1, 'n': 1, 'q': 1, 'p': 1, 's': 1, 't': 1, 'w': 1, 'v': 1, 'y': 1, 'x': 1, 'z': 1})
在本例中,空格显然是被计算在内的,但是否要过滤这些空格则由您决定。
对于dict.get(a_key, default_value)
,这个问题有几个答案--这个方法返回键的值,或者您提供的default_value。第一个参数是您要查找的键,第二个参数是该键不存在时的默认值。
https://stackoverflow.com/questions/2068349
复制相似问题