为什么此python字符序列代码会产生意外结果?

时间:2019-04-27 00:34:02

标签: python python-3.x dictionary frequency

我正在编写一个python程序来查找单词中的字符序列。但是程序给出了意外的结果。 我发现了一个类似的程序,可以很好地工作。 对我来说,我认为这两个程序非常相似,但不知道为什么其中一个不起作用

  1. 无法正常运行的程序:
# 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)
  1. 正在运行的程序:
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'))
  1. 第一个程序的输出如下:

输入字符串:google.com

{'g': 1, 'c': 1, 'm': 1, 'o': 1, 'l': 1, '.': 1, 'e': 1}
  1. 第二个程序的输出是:

{'c': 1, 'e': 1, 'o': 3, 'g': 2, '.': 1, 'm': 1, 'l': 1}

以上是正确的输出。

现在让我想起问题。

i。为什么第一个程序无法正常运行?

ii。这两个程序的意识形态是否不同?

2 个答案:

答案 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个问题的答案:

  1. 因为语句letter != dict.keys()始终为True,所以键计数没有增加。只需将其更改为letter not in dict.keys()。并且最好使用d代替dict,以便使语句看起来像letter not in d.keys()

  2. 两个程序的逻辑相同,即遍历字典,检查字典中是否存在键。如果不存在,请创建一个新的密钥,其计数为1,否则将相关计数增加1

非常感谢。