为什么在下面的代码中x和y是字符串而不是整数?

(注:在Python 2。X使用raw_input()。在Python 3中。X使用input()。在Python 3.x中raw_input()被重命名为input()

play = True

while play:

    x = input("Enter a number: ")
    y = input("Enter a number: ")

    print(x + y)
    print(x - y)
    print(x * y)
    print(x / y)
    print(x % y)

    if input("Play again? ") == "no":
        play = False

当前回答

多个问题要求在一行上输入多个整数。最好的方法是一行一行地输入整串数字,然后把它们分割成整数。下面是Python 3的版本:

a = []
p = input()
p = p.split()      
for i in p:
    a.append(int(i))

你也可以使用列表推导式:

p = input().split("whatever the seperator is")

要将所有输入从string转换为int,我们执行以下操作:

x = [int(i) for i in p]
print(x, end=' ')

列表元素应该以直线形式打印。

其他回答

input() (Python 3)和raw_input() (Python 2)总是返回字符串。使用int()显式地将结果转换为整数。

x = int(input("Enter a number: "))
y = int(input("Enter a number: "))

虽然在你的例子中,int(input(…))在任何情况下都是有效的,但python-future的内置。input是值得考虑的,因为它可以确保你的代码适用于Python2和python3,并禁用Python2的默认输入行为,试图“聪明”地处理输入数据类型(内置。Input基本上就像raw_input)。

解决方案

从Python 3开始,input返回一个字符串,你必须显式地将其转换为int,就像这样

x = int(input("Enter a number: "))
y = int(input("Enter a number: "))

您可以接受任何进制的数字,并使用int函数将其直接转换为以10为进制,如下所示

>>> data = int(input("Enter a number: "), 8)
Enter a number: 777
>>> data
511
>>> data = int(input("Enter a number: "), 16)
Enter a number: FFFF
>>> data
65535
>>> data = int(input("Enter a number: "), 2)
Enter a number: 10101010101
>>> data
1365

第二个参数告诉输入的数字的底数,然后在内部理解并转换它。如果输入的数据错误,它将抛出ValueError。

>>> data = int(input("Enter a number: "), 2)
Enter a number: 1234
Traceback (most recent call last):
  File "<input>", line 1, in <module>
ValueError: invalid literal for int() with base 2: '1234'

对于可以有分数分量的值,类型将是float而不是int:

x = float(input("Enter a number:"))

Python 2和3之间的区别

总结

Python 2的输入函数计算接收到的数据,隐式地将其转换为整数(阅读下一节以了解其含义),但Python 3的输入函数不再这样做了。 Python 2与Python 3的输入等价的是raw_input函数。

Python 2. x

有两个函数用于获取用户输入,分别称为input和raw_input。它们之间的区别是,raw_input不计算数据,而是以字符串形式返回。但是,输入将计算您输入的任何内容,并将返回计算的结果。例如,

>>> import sys
>>> sys.version
'2.7.6 (default, Mar 22 2014, 22:59:56) \n[GCC 4.8.2]'
>>> data = input("Enter a number: ")
Enter a number: 5 + 17
>>> data, type(data)
(22, <type 'int'>)

对数据5 + 17进行计算,结果为22。当它计算表达式5 + 17时,它检测到您正在将两个数字相加,因此结果也是相同的int类型。因此,类型转换是免费完成的,22作为输入的结果返回并存储在数据变量中。你可以把input看作是由eval调用组成的raw_input。

>>> data = eval(raw_input("Enter a number: "))
Enter a number: 5 + 17
>>> data, type(data)
(22, <type 'int'>)

注意:在Python 2.x中使用输入时应该小心。在这个回答中,我解释了为什么人们在使用它时应该小心。

但是,raw_input并不计算输入,而是以字符串的形式返回。

>>> import sys
>>> sys.version
'2.7.6 (default, Mar 22 2014, 22:59:56) \n[GCC 4.8.2]'
>>> data = raw_input("Enter a number: ")
Enter a number: 5 + 17
>>> data, type(data)
('5 + 17', <type 'str'>)

Python 3. x

Python 3。x的输入和Python 2。Python 3.x中的raw_input是类似的,raw_input在Python 3.x中不可用。

>>> import sys
>>> sys.version
'3.4.0 (default, Apr 11 2014, 13:05:11) \n[GCC 4.8.2]'
>>> data = input("Enter a number: ")
Enter a number: 5 + 17
>>> data, type(data)
('5 + 17', <class 'str'>)

在Python 3中。在Python 2. x中,raw_input被重命名为input。X输入被移除。

这意味着,就像raw_input一样,Python 3中的input。X总是返回一个字符串对象。

为了解决这个问题,你需要显式地将这些输入放入int中,使它们成为整数:

x = int(input("Enter a number: "))
y = int(input("Enter a number: "))

转换为整数:

my_number = int(input("enter the number"))

浮点数也类似:

my_decimalnumber = float(input("enter the number"))