python2的默认编码方式是ASCII,而python3的默认编码方式是Unicode,因此我们在python2的脚本开始处经常可以看到类似下面的一行注释
# coding:utf-8
这行注释告诉python解释器,编码方式是utf-8,当然这句话的形式可能有以下的几种方式。
# coding:utf-8
# *-* coding:utf-8 *-*
# coding=utf-8
它们之间没有什么区别,不过第二行的书写方式使得标记看起来更加明显而已。
注意,指明编码方式是utf-8的这行仅在python文件的第一行或者第二行时生效。
在python2中提供了raw_input和input两个函数,而在python3中的input函数是raw_input函数的重命名,在python3中没有了raw_input函数。
在python2中input函数的输入被当做python代码,是可以直接执行的。例如:
#! /usr/bin/env python2
# *-* coding:utf-8 *-*
data = input("请输入内容:")
print data
以下面的方式执行上面这段代码。
$ ./input_python2.py
请输入内容:1+2
3
预期的输出结果应该是1+2,而不是实际输出的3,这是因为input函数把输入当做python代码给执行了,然后将执行结果赋值给了data变量。 由于该函数将输入当做python代码执行,因此该函数存在潜在的安全问题,如果输入是不可信的(一般而言,程序决不能相信用户的输入),那么在python2中请使用raw_input函数。
将上面代码中的input换成raw_input,执行效果如下所示:
~/mypython$ ./input_python2.py
请输入内容:1+2
1+2
如前所述,python3的input就是python2的raw_input函数的重命名。因此它的功能和python2的raw_input是一模一样。
扫码关注腾讯云开发者
领取腾讯云代金券
Copyright © 2013 - 2025 Tencent Cloud. All Rights Reserved. 腾讯云 版权所有
深圳市腾讯计算机系统有限公司 ICP备案/许可证号:粤B2-20090059 深公网安备号 44030502008569
腾讯云计算(北京)有限责任公司 京ICP证150476号 | 京ICP备11018762号 | 京公网安备号11010802020287
Copyright © 2013 - 2025 Tencent Cloud.
All Rights Reserved. 腾讯云 版权所有