我正在编写一个python程序来查找单词中的字符序列。但是程序给出了意外的结果。 我发现了一个类似的程序,可以很好地工作。 对我来说,我认为这两个程序非常相似,但不知道为什么其中一个不起作用
# Display the character sequence in a word
dict={}
string=input("Enter the string:").strip().lower()
for letter in string:
if letter !=dict.keys():
dict[letter]=1
else:
dict[letter]=dict[letter]+1
print(dict)
def char_frequency(str1):
dict = {}
for n in str1:
keys = dict.keys()
if n in keys:
dict[n] += 1
else:
dict[n] = 1
return dict
print(char_frequency('google.com'))
输入字符串:google.com
{'g': 1, 'c': 1, 'm': 1, 'o': 1, 'l': 1, '.': 1, 'e': 1}
{'c': 1, 'e': 1, 'o': 3, 'g': 2, '.': 1, 'm': 1, 'l': 1}
以上是正确的输出。
现在让我想起问题。
i。为什么第一个程序无法正常运行?
ii。这两个程序的意识形态是否不同?
答案 0 :(得分:1)
这行是荒谬的:
if letter !=dict.keys():
letter
的长度为str
,而dict.keys()
返回一个键视图对象,该对象永远不等于任何类型的str
。您的if
支票总是 错误。正确的逻辑是:
if letter not in dict:
(如果您确实愿意,可以添加.keys()
,但这是浪费和毫无意义的;在dict
上的成员资格测试正在隐式检查其密钥)。
旁注:您将通过命名变量dict
来混淆自己,因为您在名称dict
构造函数上添加了阴影;如果您需要使用它,则该范围将不可用。尽量不要掩盖内置名称。
答案 1 :(得分:1)
实际上,您使用的if语句有一个小错误。只需看看下面的修改程序即可。
注意:另外,请确保不要将诸如 dict 之类的预定义数据类型名称用作变量名称。我已将其更改为 d 。
>>> d = {}
>>>
>>> string=input("Enter the string:").strip().lower()
Enter the string:google.com
>>>
>>> for letter in string:
... if letter not in d.keys():
... d[letter] = 1
... else:
... d[letter] = d[letter] + 1
...
>>> print(d)
{'g': 2, 'o': 3, 'l': 1, 'e': 1, '.': 1, 'c': 1, 'm': 1}
>>>
您还可以查看在终端上执行的以下语句。
将键与 d.keys()进行比较,将始终返回False
,因为 key 是此处的字符串,并且 d.keys()始终是dict_keys
(Python3)和list
(Python2)类型的对象。
>>> d = {"k1": "v1", "k3": "v2", "k4": "Rishi"}
>>>
>>> d.keys()
dict_keys(['k1', 'k3', 'k4'])
>>>
>>> "k1" in d
True
>>>
>>> not "k1" in d
False
>>>
>>> "k1" == d.keys()
False
>>>
>>> "k1" not in d
False
>>>
您的2个问题的答案:
因为语句letter != dict.keys()
始终为True
,所以键计数没有增加。只需将其更改为letter not in dict.keys()
。并且最好使用d
代替dict
,以便使语句看起来像letter not in d.keys()
。
两个程序的逻辑相同,即遍历字典,检查字典中是否存在键。如果不存在,请创建一个新的密钥,其计数为1
,否则将相关计数增加1
。
非常感谢。