查看原文
其他

Python2与Python3的区别,你都知道吗?

柯广 数据科学专栏 2022-10-15


自从Python3系列版本的出现,很多熟悉Python2的老司机们经常在Python3上写在Python2上不会出错的代码,浪费了很多时间,抱怨又得学习语法规则了,很多新手更是头疼,不知学习哪个版本好。下面我就我所知道的Python2与Python3区别给大家罗列一下哎,可能不够全面,并且Python一直在不断地更新、维护中,或许我们需要发现知识、积累知识吧,希望对小菜鸟们有用!


1、输入输出函数

(1)、print()函数

原来:print 变量名 或者print(变量名)

现在:print(变量名)

          print 变量名    %报错

(2)、input(0函数

原来:变量=raw_input('变量=')

现在:变量=input('变量=')


2、Unicode编码

Python2 有 ASCII str() 类型,unicode() 是单独的,不是 byte 类型。

现在, 在 Python3,我们最终有了 Unicode (utf-8) 字符串,以及一个字节类:byte 和 bytearrays。


Python2

>>> str = "我爱大中国"

>>> str

'\xe6\x88\x91\xe7\x88\xb1\xe5\x8c\x97\xe4\xba\xac\xe5\xa4\xa9\xe5\xae\x89\xe9\x97\xa8'


Python3

>>> str = "我爱大中国"

>>> str

'我爱大中国'


并且,由于 Python3.X 源码文件默认使用utf-8编码,这就使得以下代码是合法的:

>>> 我爱大中国='我爱大中国'

>>> 我爱大中国

'我爱大中国'

汉字可以做变量了,准确说是变量的引用,这对于我们这些英语差的算是一大福利咯。


3、除法运算

Python中的除法较其它语言显得非常高端,有套很复杂的规则。

(1)、/ 除法

Python2:

>>> 1 / 2

0

>>> 1.0 / 2.0

0.5

Python3:

>>> 1/2

0.5

(2)、//除法

Python中的“//”运算符相当于数学中的[a/b],a//b返回小于a/b的最大整数。在Python2与Python3中并没有区别:

Python2:

>>> -1 // 2

-1

Python3:>>> -1//2

-1


4、异常

在 Python 3 中处理异常也轻微的改变了,在 Python 3 中我们现在使用 as 作为关键词。捕获异常的语法由 except exc, var 改为 except exc as var。使用语法except (exc1, exc2) as var可以同时捕获多种类别的异常。 Python 2.6已经支持这两种语法。


1. 在2.x时代,所有类型的对象都是可以被直接抛出的,在3.x时代,只有继承自BaseException的对象才可以被抛出。

2. 2.x raise语句使用逗号将抛出对象类型和参数分开,3.x取消了这种奇葩的写法,直接调用构造函数抛出对象即可。

在2.x时代,异常在代码中除了表示程序错误,还经常做一些普通控制结构应该做的事情,在3.x中可以看出,设计者让异常变的更加专一,只有在错误发生的情况才能去用异常捕获语句来处理。


5、xrange()函数

在Python2与Python3中,xrange()与range()都是产生一个遍历序列。


Python2

>>> for i in xrange(3):

print(i)

0

1

2

Python3中xrange()已经丢弃,那样用只会出错

>>> for i in range(3):

print(i)

0

1

2


6、八进制表示

八进制数必须写成0o777,原来的形式0777不能用了;二进制必须写成0b111。新增了一个bin()函数用于将一个整数转换成二进制字串。 Python 2.6已经支持这两种语法。在Python 3中,表示八进制字面量的方式只有一种,就是0o1000。


Python2

>>> 0o1000

512

>>> 01000

512

Python3

>>> 0o1000

512


7、不等运算符

Python 2中不等于有两种写法 != 和 <>,Python 3中去掉了<>, 只有!=一种写法,还好,我从来没有使用<>的习惯。


8、数据类型

Python3去除了long类型,现在只有一种整型——int,但它的行为就像Python版本的long。


(1)、新增了bytes类型,对应于2.X版本的八位串,定义一个bytes字面量的方法如下:

>>>a=b'中国'

SyntaxError: bytes can only contain ASCII literal characters.

>>> a=b'hello world!'

>>> type(a)

<class 'bytes'>

(2)、str对象和bytes对象可以使用.encode() (str -> bytes) or .decode() (bytes -> str)方法相互转化。

>>> s = a.decode() 

>>> s 

'hello owrld!' 

>>> b1 = s.encode() 

>>> b1 

b'hello world!' 

(3)、dict的.keys()、.items 和.values()方法返回迭代器,而之前的iterkeys()等函数都被废弃。同时去掉的还有 dict.has_key(),用 in替代它吧 。


9、去掉了repr表达式

Python2中反引号``相当于repr函数的作用,Python3中去掉了``这种写法,只允许使用repr函数,这样做的目的是为了使代码看上去更清晰么?不过我感觉用repr的机会很少,一般只在debug的时候才用,多数时候还是用str函数来用字符串描述对象。


10、多个模块被改名(根据PEP8)

原来名字                 现在名字

_winreg                 winreg

ConfigParser     configparser

copy_reg             copyreg

Queue               queue

SocketServer     socketserver

repr                         reprlib

-----------------------------------

StringIO模块现在被合并到新的io模组内。 new, md5, gopherlib等模块被删除。 Python 2.6已经支援新的io模组。httplib, BaseHTTPServer, CGIHTTPServer, SimpleHTTPServer, Cookie, cookielib被合并到http包内。取消了exec语句,只剩下exec()函数。 Python 2.6已经支援exec()函数。


11、有些模块的导入

Python2

import thread

Python3

import _thread


12、性能

Python3运行要比速度Python2慢。所以Python3还有极大的优化空间。 但我们要看到Python3与Python2相比在很多方面的进步,以后的趋势应该是Python3慢慢取代Python2的。总之,时代在发展,社会在进步,新旧事物的更迭,一切都在前进。


觉得不错记得【点赞分享】哦!点击【阅读原文】查看历史文章。

您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存