首先python2是python3的下位版本,目前应该是到2.7版本截止,往后不会再发展但会一直对python2有维护。
针对py3和py2的差异分为以下几点:
python3中被削减的功能:
1.内置类型的方法被废除
python3将python2用来检查字典的键的方法has_key()去除掉了,与之对应新使用的是key in d这样的“in”运算符,这个功能在python2中也可以使用。
2.xrange()函数被废除
内置函数range()是我们熟悉的老朋友,用于生成正在循环的序列中,
用法:
range(start, stop[, step])
而在python2中,更推荐使用xrange()函数,这是因为range()函数生成的是列表对象,如果元素太多会很占内存,而xrange()是返回类似于迭代器的对象,当for语句需要循环时就可以直接生成下一个元素并返回,就节省了很多空间。
BUT,现在python3中也range()也开始返回迭代器对象了,所以,xrange()也就没有存在的必要了(这算是借尸还魂吧哈哈)
相似地,python3中,map(),filter(),zip()这样的函数也都开始返回迭代器了
python2.7中可以使用的python3的功能:
1.print_function
利用“from __future__ import print_function”可以将python2的print语句更改为print()函数
2.unicode_literals
利用“from __future__ import unicode_literals”可以将字符串(str)类型的字面量作为字符串来处理。
python3与python2相比发生变化的功能:
1.Unicode字符串
python2中有两种字符串类型:
·str字符串
·Unicode字符串
Unicode字符串的定义:
ustr=u"Hello 黔肆"
print(ustr)
str和unicode编码时,在计算字符时的方法是不一样的:
import sys
ustr=u"hello ペキン"
str1="hello ペキン"
bytestr2=str1.encode()
print(ustr,len(ustr),sys.getsizeof(ustr))
print(str1,len(bytestr2),sys.getsizeof(str1))
#输出:
#hello ペキン 9 92
#hello ペキン 15 92
到python3.3后也可以支持用u“xxx”来定义Unicode字符串了
python 2.x默认的字符编码是ASCII,默认的文件编码也是ASCII。
python 3.x默认的字符编码是unicode,默认的文件编码是utf-8。
2.print语句
python3的print()中新增了赋予参数来控制执行,如不换行和更改输出位置:
print("没完呢",end="")
print("ahhhh",file="xxx.txt")
完整的参数使用下:
print(*objects, sep=' ', end='\n', file=sys.stdout, flush=False)
3.input()函数
4.int类型与long类型的综合
python2中根据数值大小分为两种数据类型:依存于c语言long的int和在内存允许范围内尽最大可能处理的long类型(在字面量后加L)
python3将其综合成与py2中的long类型相当的类型,废除了字面量后加L的用法
5.关于除法的更改
python2与C语言的整形除法类似,1/2得到是0
python3更改为1/2得到不再是取整的整数,而是float:0.5,而用1//2来代替求商取整
6.二进制、八进制字面量记载
python2中10的八进制的记载是:022
python3中10的八进制的记载是:0o22
python2中没有二进制的字面量
python3中增加二进制的字面量:0b110 (6)
7.与异常相关的变更
python2.6之前是这样的格式:
try: #捕捉异常的处理
pass
except OSError,e: #异常发生时的处理
pass
python2.7及之后仍可使用上述格式,python3新增以下格式:
try: #捕捉异常的处理
pass
except OSError as e: #异常发生时的处理
pass
“as e”也可省略
8.关于对象比较的变更
python2中对于不用对象的比较也是可以的,而且一致返回True。例如:
>>>1>"1"?
>>>True
python3中不同的对象之间就不能比较,会出现异常。