一直想学python
,没有时间学(给自己的拖延找了个好借口,哈哈), 最近终于行动起来了,系统学一下python
,当然在学python
之间先了解一下python
的历史,python2.x
和python3.x
的区别:
Python
的 3.0 版本,常被称为 Python 3000
,或简称 Py3k
。相对于 Python 的早期版本,这是一个较大的升级。
为了不带入过多的累赘,Python 3.0
在设计的时候没有考虑向下相容。
许多针对早期Python
版本设计的程式都无法在 Python 3.0
上正常执行。
为了照顾现有程式,Python 2.6
作为一个过渡版本,基本使用了 Python 2.x
的语法和库,同时考虑了向 Python 3.0
的迁移,允许使用部分Python 3.0
的语法与函数。
新的 Python
程式建议使用 Python 3.0
版本的语法。
除非执行环境无法安装 Python 3.0
或者程式本身使用了不支援 Python 3.0
的第三方库。目前不支持Python 3.0
的第三方库有 Twisted, py2exe, PIL
等。
大多数第三方库都正在努力地相容 Python 3.0
版本。即使无法立即使用 Python 3.0
,也建议编写相容 Python 3.0
版本的程式,然后使用 Python 2.6, Python 2.7
来执行。
Python 3.0
的变化主要在以下几个方面:
1:print
函数
在python3.x
中print
语句没有了,取而代之的是print()
函数,Python2.6
与Python2.7
部分的支持这种形式的print
语法。
在python2.6
与python2.7
里面,一下三种形式是等价的:
print "hello"
print ("hello") #注意print后面有个空格
print("hello") #注意print()不能带有任何其它参数
如果python2.x
版本想使用python3.x
的print
函数,可以导入_future_
包,该包禁用python2.x
的print
语句,采用python3.x
的print
函数,如:
>>> name = "小李"
>>> print name #python2.x的print语句
>>> from _futrue_ import print_function #导入_future包
>>> print name #再这样使用python2.x的print语句,会报错
>>>print (name) #使用python3.x的print函数是正常的
python3.x
与python2.x
的许多兼容性设计的功能可以通过_future_
这个包来导入。
2:Unicode
Python 2
有ASCII str()
类型,Unicode()
是单独的,不是byte
类型。
Python 2
有Unicode(utf-8)
字符串,以及一个字节类:byte
和bytearrays.
由于Python3.x
源码文件默认使用utf-8
编码,所以使用中文就更加方便了。
3:除法运算
Python
中的除法较其它语言显得非常高端,有套很复杂的规则。python
中的除法有两个运算符,/
和//
,首先来说/
除法:
在Python2.x
中/除法就是整数相除的结果是一个整数,把小数部分完全忽略掉,浮点数除法会保留小数点的部分得到一个浮点数的结果。
如:
>>> 1 / 2
0
>>> 1.0 / 2.0
0.5
在Python3.x
中/除法不再这么做了,对于整数之间的相除,结果也会是浮点数。
如:
>>> 1/2
0.5
而对于//
除法,这种除法叫做floor
除法,会对除法的结果自动进行一个floor
操作,在Python2.x
和Python3.x
中是一致的。
3:异常
Python 3
中处理异常也轻微的改变了,在 Python 3
中我们现在使用 as
作为关键词。
捕获异常的语法由 except exc, var
改为 except exc as var
。
使用语法except (exc1, exc2) as var
可以同时捕获多种类别的异常。 Python 2.6
已经支持这两种语法。
- 在
2.x
时代,所有类型的对象都是可以被直接抛出的,在3.x
时代,只有继承自BaseException
的对象才可以被抛出。 -
2.x raise
语句使用逗号将抛出对象类型和参数分开,3.x
取消了这种奇葩的写法,直接调用构造函数抛出对象即可。
在2.x
时代,异常在代码中除了表示程序错误,还经常做一些普通控制结构应该做的事情,在3.x
中可以看出,设计者让异常变的更加专一,只有在错误发生的情况才能去用异常捕获语句来处理。
3: xrange
在Python 2 中 xrange()
创建迭代对象的用法是非常流行的。比如:for
循环或者是列表/集合/字典推导式。
这个表现十分像生成器(比如。"惰性求值")。但是这个 xrange-iterable 是无穷的,意味着你可以无限遍历。
由于它的惰性求值,如果你不得仅仅不遍历它一次,xrange()
函数 比range()
更快(比如for
循环)。尽管如此,对比迭代一次,不建议你重复迭代多次,因为生成器每次都从头开始。
在Python 3
中,range()
是像xrange()
那样实现以至于一个专门的xrange()
函数都不再存在(在Python 3
中xrange()
会抛出命名异常)。
4: 不等运算符
Python 2.x
中不等于有两种写法!=
和<>
,
Python 3.x
中去掉了<>
, 只有!=
一种写法。
5:数据类型
1>Python3.x
去除了long
类型,现在只有一种整型--int
,但它的行为就像2.x
版本的long
。
2>新增了bytes
类型,对应于2.X
版本的八位串,定义一个bytes
字面量的方法如下:
>>> b = b'china'
>>> type(b)
<type 'bytes'>