新手从Python的哪个版本开始学比较好?

想学习Python的人都会有一个困惑,那就是Python目前有两个版本Python2和Python3,Python2与Python3有何区别,两个版本该学习哪个呢?

python3 和 python2 是不兼容的,而且差异比较大,python3是不向下兼容的,但是绝大多数组件和扩展都是基于python2的。目前实际应用中大部分暂不考虑 Python3,有的时候注意写兼容 2/3 的代码。用 Python2 为主的写新代码时要考虑以后迁移到 Python3 的可能性。据数据统计显示目前10% 使用 Python 3;20% 既使用Python 2也使用Python 3,Python 2用的更多;70% 使用Python 2。

其实python是linux上最常用的软件之一,但是linux目前的版本大部分还是使用python2的,而且,在linux上依赖python2的程序更多一些,所以 Python3 要代替 python2 成为主流还需要几年的时间。如果为了找工作还是学Python 2,学会了Python 2,由Python 2转到python3也不难。

说了半天,Python2与Python3到底有何区别呢?

1.性能
Py3.0运行 pystone benchmark的速度比Py2.5慢30%。Guido认为Py3.0有极大的优化空间,在字符串和整形操作上可以取得很好的优化结果。 
Py3.1性能比Py2.5慢15%,还有很大的提升空间。 
2.编码 
Py3.X源码文件默认使用utf-8编码,这就使得以下代码是合法的: 
   >>> 中国 = ‘china‘ 
   >>>print(中国) 
   china 
3. 语法
1)去除了<>,全部改用!= 
2)去除``,全部改用repr() 
3)关键词加入as 和with,还有True,False,None 
4)整型除法返回浮点数,要得到整型结果,请使用// 
5)加入nonlocal语句。使用noclocal x可以直接指派外围(非全局)变量 
6)去除print语句,加入print()函数实现相同的功能。同样的还有 exec语句,已经改为exec()函数 
   例如: 
   2.X: print "The answer is", 2*2 
   3.X: print("The answer is", 2*2) 
   2.X: print x, # 使用逗号结尾禁止换行 
   3.X: print(x, end=" ") # 使用空格代替换行 
  2.X: print # 输出新行 
  3.X: print() # 输出新行 
  2.X: print >>sys.stderr, "fatal error" 
  3.X: print("fatal error", file=sys.stderr) 
  2.X: print (x, y)

# 输出repr((x, y)) 
3.X: print((x, y)) # 不同于print(x, y)!

7)改变了顺序操作符的行为,例如x<y,当x和y类型不匹配时抛出TypeError而不是返回随即的 bool值 
8)输入函数改变了,删除了raw_input,用input代替: 
   2.X:guess = int(raw_input(‘Enter an integer : ‘)) # 读取键盘输入的方法 
   3.X:guess = int(input(‘Enter an integer : ‘))

9)去除元组参数解包。不能def(a, (b, c)):pass这样定义函数了 
10)新式的8进制字变量,相应地修改了oct()函数。 
   2.X的方式如下: 
    >>> 0666 
    438 
    >>> oct(438) 
    ‘0666‘ 
  3.X这样: 
    >>> 0666 
    SyntaxError: invalid token (<pyshell#63>, line 1) 
    >>> 0o666 
   438 
   >>> oct(438) 
   ‘0o666‘ 
11)增加了 2进制字面量和bin()函数 
   >>> bin(438) 
   ‘0b110110110‘ 
   >>> _438 = ‘0b110110110‘ 
   >>> _438 
  ‘0b110110110‘ 
12)扩展的可迭代解包。在Py3.X 里,a, b, *rest = seq和 *rest, a = seq都是合法的,只要求两点:rest是list 
对象和seq是可迭代的。 
13)新的super(),可以不再给super()传参数, 
>>> class C(object): 
def __init__(self, a): 
print(‘C‘, a) 
>>> class D(C): 
def __init(self, a): 
super().__init__(a) # 无参数调用super() 
>>> D(8) 
C 8 
<__main__.D object at 0x00D7ED90> 
14)新的metaclass语法: 
class Foo(*bases, **kwds): 
pass 
15)支持class decorator。用法与函数decorator一样: 
>>> def foo(cls_a): 
def print_func(self): 
print(‘Hello, world!‘) 
cls_a.print = print_func 
return cls_a 
>>> @foo 
class C(object): 
pass 
>>> C().print() 
Hello, world! 
class decorator可以用来玩玩狸猫换太子的大把戏。更多请参阅PEP 3129 
4. 字符串和字节串
1)现在字符串只有str一种类型,但它跟2.x版本的unicode几乎一样。

2)关于字节串,请参阅“数据类型”的第2条目 
5.数据类型
1)Py3.X去除了long类型,现在只有一种整型——int,但它的行为就像2.X版本的long 
2)新增了bytes类型,对应于2.X版本的八位串,定义一个bytes字面量的方法如下: 
>>> b = b‘china‘ 
>>> type(b) 
<type ‘bytes‘> 
str对象和bytes对象可以使用.encode() (str -> bytes) or .decode() (bytes -> str)方法相互转化。 
>>> s = b.decode() 
>>> s 
‘china‘ 
>>> b1 = s.encode() 
>>> b1 
b‘china‘ 
3)dict的.keys()、.items 和.values()方法返回迭代器,而之前的iterkeys()等函数都被废弃。同时去掉的还有 
dict.has_key(),用 in替代它吧 
6.面向对象 
1)引入抽象基类(Abstraact Base Classes,ABCs)。 
2)容器类和迭代器类被ABCs化,所以cellections模块里的类型比Py2.5多了很多。 
>>> import collections 
>>> print(‘\n‘.join(dir(collections))) 
Callable 
Container 
Hashable 
ItemsView 
Iterable 
Iterator 
KeysView 
Mapping 
MappingView 
MutableMapping 
MutableSequence 
MutableSet 
NamedTuple 
Sequence 
Set 
Sized 
ValuesView 
__all__ 
__builtins__ 
__doc__ 
__file__ 
__name__ 
_abcoll 
_itemgetter 
_sys 
defaultdict 
deque 
另外,数值类型也被ABCs化。关于这两点,请参阅 PEP 3119和PEP 3141。 
3)迭代器的next()方法改名为__next__(),并增加内置函数next(),用以调用迭代器的__next__()方法 
4)增加了@abstractmethod和 @abstractproperty两个 decorator,编写抽象方法(属性)更加方便。 
7.异常
1)所以异常都从 BaseException继承,并删除了StardardError 
2)去除了异常类的序列行为和.message属性 
3)用 raise Exception(args)代替 raise Exception, args语法 
4)捕获异常的语法改变,引入了as关键字来标识异常实例,在Py2.5中: 
>>> try: 
... raise NotImplementedError(‘Error‘) 
... except NotImplementedError, error:

... print error.message 
... 
Error 
在Py3.0中: 
>>> try: 
raise NotImplementedError(‘Error‘) 
except NotImplementedError as error: #注意这个 as 
print(str(error)) 
Error 
5)异常链,因为__context__在3.0a1版本中没有实现 
8.模块变动
1)移除了cPickle模块,可以使用pickle模块代替。最终我们将会有一个透明高效的模块。 
2)移除了imageop模块 
3)移除了 audiodev, Bastion, bsddb185, exceptions, linuxaudiodev, md5, MimeWriter, mimify, popen2, 
rexec, sets, sha, stringold, strop, sunaudiodev, timing和xmllib模块 
4)移除了bsddb模块(单独发布,可以从Python "bindings" for Oracle Berkeley DB获取) 
5)移除了new模块 
6)os.tmpnam()和os.tmpfile()函数被移动到tmpfile模块下 
7)tokenize模块现在使用bytes工作。主要的入口点不再是generate_tokens,而是 tokenize.tokenize() 
9.其它 
1)xrange() 改名为range(),要想使用range()获得一个list,必须显式调用: 
>>> list(range(10)) 
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9] 
2)bytes对象不能hash,也不支持 b.lower()、b.strip()和b.split()方法,但对于后两者可以使用 b.strip(b’ 
\n\t\r \f’)和b.split(b’ ‘)来达到相同目的 
3)zip()、map()和filter()都返回迭代器。而apply()、 callable()、coerce()、 execfile()、reduce()和reload 
()函数都被去除了

现在可以使用hasattr()来替换 callable(). hasattr()的语法如:hasattr(string, ‘__name__‘)

4)string.letters和相关的.lowercase和.uppercase被去除,请改用string.ascii_letters 等 
5)如果x < y的不能比较,抛出TypeError异常。2.x版本是返回伪随机布尔值的 
6)__getslice__系列成员被废弃。a[i:j]根据上下文转换为a.__getitem__(slice(I, j))或 __setitem__和 
__delitem__调用 
7)file类被废弃,在Py2.5中: 
>>> file 
<type ‘file‘> 
在Py3.X中: 
>>> file 
Traceback (most recent call last): 
File "<pyshell#120>", line 1, in <module> 
file 
NameError: name ‘file‘ is not defined

原文地址:https://www.cnblogs.com/Bandwagonhost/p/8383555.html

时间: 2024-10-11 12:51:04

新手从Python的哪个版本开始学比较好?的相关文章

写给新手的Python导入机制详解

原创作品,转载引用请注明出处及作者 开篇说明 正文 '隐藏在导入背后的'对象 命名空间.dir函数与代码复用 import分两步操作 同一模块只会加载一次 模块搜索顺序 sys.path[0] 包机制 包的实质 from...import 相对导入 总结 开篇说明 本文旨在帮助Python新手对Python导入机制应用层面做一个全面了解.由于我也是一个Python新手,所以通篇介绍的只是应用层面的内容,导入机制背后的函数等诸多细节没有涉及.如果要深究,请自行参考Python语言参考手册.本文基于

2019年Python、Java、C++学哪个更好?薪资更高?

首先,我认为编程语言是没有最好,只有最合适.但是未来预测这种事还是留给大神,这边就分享给楼主一些"干货" 最后,如果大家如果在自学遇到困难,想找一个C++的学习环境,可以加入我们的C++学习圈,点击我加入吧,会节约很多时间,减少很多在学习中遇到的难题. Python 难度:★ 欢迎度:★★★★☆ 创始于:1991年 学完之后可以干什么: web开发.应用开发.大数据.数据挖掘.科学计算.机器学习.人工智能.运维.自然语言处理等等等. 就业薪资: 2019年Python.Java.C++

Windows 下让 Python 多个版本共存(支持 pip)

转载自 http://blog.kgzx.net/index.php/archives/40/ 因为类库兼容性的关系,写实际项目时都是用 Python 2,但自己试验性的写点小东西还是喜欢用 Python 3在这记录一下在 windows 下让这两个版本共存的配置步骤 在官网下载两个版本的 exe 文件并安装.因为我主要用 v2,所以把它放在 后面 安装.这样在调用 python 命令时,默认执行的就行 v2 版本的 进入 v3 的安装文件夹,把 python.exe 和 pythonw.exe

Effective Python 条目一:知道你现在用的Python是哪个版本

条目一:知道你现在用的Python是哪个版本 在这本书里,主要实例的代码是Python3.4(发布于2014年3月17日)的语法.这本书也提供一些Python2.7(发布于2010年七月3日)语法的例子去强调不同之处.我的大部分建议都可应用到流行的Python运行时库:CPython, Jython, IronPython, PyPy, etc. 很多计算机预装了多个版本的标准CPython运行时库.然而,命令行中默认的python并不清晰.python通常是python2.7的别名,但是有时候

将Python自带版本(2.6.6)升级到2.7.9

将Python自带版本(2.6.6)升级到2.7.9 查看当前python版本: # pythonPython 2.6.6 (r266:84292, Jan 22 2014, 09:42:36)  [GCC 4.4.7 20120313 (Red Hat 4.4.7-4)] on linux2Type  "help", "copyright", "credits" or "license" for more informati

python3.6 和python 2.7版本安装pycrypto过程及问题(不需要安装vs)

python安装pycrypto真的是踩到很多坑,说起来一把辛酸泪,好在最后成功解决了,总结了一下遇到的问题,写出来与大家共享 首先要明白的是crypto和pycrypto是两个不同的模块,小伙伴们不要去安装crypto 问题一:unable to find vcvarsall.bat 在网上下载pycrypto的包,进入包目录,使用python setup.py install命令安装,报错如图 大家看到这肯定去百度啊,百度就告诉你安装vs吧,但vs这个东西安装时间长,卸载又麻烦,加上我们平时

用setuptools_scm来自动控制Python包的版本

手动管理Python包的版本号一段时间后,寻求自动化的手段,是自然而然的. 手动管理版本 手动管理Python包的版本,需要注意两个方面: 每次发布新包前,要更新包的版本号. 在安装后的默认模块下应该有一个__version__变量,其值为版本号. 关于第一点,可以参考<PEP 440 -- Version Identification and Dependency Specification>: 关于第二点,可以参考<PEP 396 -- Module Version Numbers&

查看python和NumPy版本和安装路径

记录查看Python和NumPy版本以及路径的几条命令 # 查看Python版本及路径 python -V python -c "import sys;print(sys.executable)" # 查看NumPy版本及路径 python -c "import numpy;print(numpy.version.version)" python -c "import numpy;print(numpy.__version__)" # 借助pip

ubuntu中更改python的默认版本

转:https://www.cnblogs.com/dylancao/p/10219956.html 一般Ubuntu默认的Python版本都为2.x, 如何改变Python的默认版本呢?假设我们需要把Python3.5设置为默认版本:首先查看Python默认版本: [email protected]~$:python --version Python 2.7 搜索系统是否已经安装Python3.5: [email protected]~$:whereis python3.5 如果结果里有/us