- N +

python2和python3的區(qū)別?python和c++學哪個好

本篇文章給大家談?wù)刾ython2和python3的區(qū)別,以及python和c++學哪個好對應(yīng)的知識點,文章可能有點長,但是希望大家可以閱讀完,增長自己的知識,最重要的是希望對各位有所幫助,可以解決了您的問題,不要忘了收藏本站喔。

python2和python3哪個用得多

python2和python3哪個都好用,Python奉行簡潔主義,易于讀寫;開源免費;兼容眾多平臺;既支持面向過程,也支持面向?qū)ο缶幊蹋粯藴蕩焓重S富;采用強制縮進的方式使得代碼具有極佳的可讀性;具有可擴展性和可嵌入性,等等。

python一般用哪一個版本

Python有兩個主要版本,Python2和Python3。目前官方已經(jīng)停止了對Python2的維護,建議使用Python3版本。同時,隨著時間的推移,越來越多的Python庫和框架也開始支持Python3,因此Python3也是目前使用最廣泛的版本。

Python 2和Python 3有哪些主要區(qū)別

語法

print不再是語句,而是函數(shù),比如原來是print'abc'現(xiàn)在是print('abc')但是python2.6+可以使用fromfutureimportprint_function來實現(xiàn)相同功能在Python3中,沒有舊式類,只有新式類,也就是說不用再像這樣classFoobar(object):pass顯式地子類化object原來1/2(兩個整數(shù)相除)結(jié)果是0,現(xiàn)在是0.5了

#python2>>>1/20

#python3>>>1/20.5

異常的寫法改變:原來的exceptException,e變成except(Exception)ase

編碼

Python2的默認編碼是asscii,這也是導致Python2中經(jīng)常遇到編碼問題的原因之一,至于是為什么會使用asscii作為默認編碼,原因在于Python這門語言誕生的時候還沒出現(xiàn)Unicode。Python3默認采用了UTF-8作為默認編碼,因此你不再需要在文件頂部寫#coding=utf-8了。

#python2>>>printsys.getdefaultencoding()ascii#python3>>>print(sys.getdefaultencoding())utf-8

字符串

字符串是最大的變化之一,這個變化使得編碼問題降到了最低可能。在Python2中,字符串有兩個類型,一個是unicode,一個是str,前者表示文本字符串,后者表示字節(jié)序列,不過兩者并沒有明顯的界限,開發(fā)者也感覺很混亂,不明白編碼錯誤的原因,不過在Python3中兩者做了嚴格區(qū)分,分別用str表示字符串,byte表示字節(jié)序列,任何需要寫入文本或者網(wǎng)絡(luò)傳輸?shù)臄?shù)據(jù)都只接收字節(jié)序列,這就從源頭上阻止了編碼錯誤的問題。

>>>s='中文'>>>s'中文'>>>type(s)<class'str'>#上面的str類型對象實際上相當于py2的unicodes.encode('utf-8')b'\xe4\xb8\xad\xe6\x96\x87'#str對象encodeutf-8后,變成bytes對象,所以bytes對象取代了py2的str對象

所以:

py2->unicode->被py3的str對象代替py2->str->被py3的bytes對象代替

py2與py3字符串差異比較

迭代器

在Python2中很多返回列表對象的內(nèi)置函數(shù)和方法在Python3都改成了返回類似于迭代器的對象,因為迭代器的惰性加載特性使得操作大數(shù)據(jù)更有效率。Python2中的range和xrange函數(shù)合并成了range,如果同時兼容2和3,可以這樣:

try:range=xrangeexcept:pass

另外,字典對象的dict.keys()、dict.values()方法都不再返回列表,而是以一個類似迭代器的"view"對象返回。高階函數(shù)map、filter、zip返回的也都不是列表對象了。Python2的迭代器必須實現(xiàn)next方法,而Python3改成了next。

map方法返回了迭代器而不再是列表

#py2#直接返回列表>>>map(lambdax:x*x,range(1,3))[1,4]#py3#返回迭代器>>>map(lambdax:x*x,range(1,3))<mapobjectat0x7f45371e5c18>#需要遍歷才能讀取,這樣對于大數(shù)據(jù)會更高效率>>>map_data=map(lambdax:x*x,range(1,3))>>>forminmap_data:...print(m)...14

asyncio異步IO模型

asyncio是Python3.4版本引入的標準庫,直接內(nèi)置了對異步IO的支持。

asyncio的編程模型就是一個消息循環(huán)。我們從asyncio模塊中直接獲取一個EventLoop的引用,然后把需要執(zhí)行的協(xié)程扔到EventLoop中執(zhí)行,就實現(xiàn)了異步IO。

現(xiàn)在學Python應(yīng)該學2還是3

首先感謝邀請,學Python2或者3,先了解一下二者之間的區(qū)別。

1.性能

Py3.0運行pystonebenchmark的速度比Py2.5慢30%。Guido認為Py3.0有極大的優(yōu)化空間,在字符串和整形操作上可

以取得很好的優(yōu)化結(jié)果。

Py3.1性能比Py2.5慢15%,還有很大的提升空間。

2.編碼

Py3.X源碼文件默認使用utf-8編碼,這就使得以下代碼是合法的:

>>>中國='china'

>>>print(中國)

china

3.語法

1)去除了<>,全部改用!=

2)去除``,全部改用repr()

3)關(guān)鍵詞加入as和with,還有True,False,None

4)整型除法返回浮點數(shù),要得到整型結(jié)果,請使用//

5)加入nonlocal語句。使用noclocalx可以直接指派外圍(非全局)變量

6)去除print語句,加入print()函數(shù)實現(xiàn)相同的功能。同樣的還有exec語句,已經(jīng)改為exec()函數(shù)

例如:

2.X:print"Theansweris",2*2

3.X:print("Theansweris",2*2)

2.X:printx,#使用逗號結(jié)尾禁止換行

3.X:print(x,end="")#使用空格代替換行

2.X:print#輸出新行

3.X:print()#輸出新行

2.X:print>>sys.stderr,"fatalerror"

3.X:print("fatalerror",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)輸入函數(shù)改變了,刪除了raw_input,用input代替:

2.X:guess=int(raw_input('Enteraninteger:'))#讀取鍵盤輸入的方法

3.X:guess=int(input('Enteraninteger:'))

9)去除元組參數(shù)解包。不能def(a,(b,c)):pass這樣定義函數(shù)了

10)新式的8進制字變量,相應(yīng)地修改了oct()函數(shù)。

2.X的方式如下:

>>>0666

438

>>>oct(438)

'0666'

3.X這樣:

>>>0666

SyntaxError:invalidtoken(<pyshell#63>,line1)

>>>0o666

438

>>>oct(438)

'0o666'

11)增加了2進制字面量和bin()函數(shù)

>>>bin(438)

'0b110110110'

>>>_438='0b110110110'

>>>_438

'0b110110110'

12)擴展的可迭代解包。在Py3.X里,a,b,*rest=seq和*rest,a=seq都是合法的,只要求兩點:rest是list

對象和seq是可迭代的。

13)新的super(),可以不再給super()傳參數(shù),

>>>classC(object):

def__init__(self,a):

print('C',a)

>>>classD(C):

def__init(self,a):

super().__init__(a)#無參數(shù)調(diào)用super()

>>>D(8)

C8

<__main__.Dobjectat0x00D7ED90>

14)新的metaclass語法:

classFoo(*bases,**kwds):

pass

15)支持classdecorator。用法與函數(shù)decorator一樣:

>>>deffoo(cls_a):

defprint_func(self):

print('Hello,world!')

cls_a.print=print_func

returncls_a

>>>@foo

classC(object):

pass

>>>C().print()

Hello,world!

classdecorator可以用來玩玩貍貓換太子的大把戲。更多請參閱PEP3129

4.字符串和字節(jié)串

1)現(xiàn)在字符串只有str一種類型,但它跟2.x版本的unicode幾乎一樣。

2)關(guān)于字節(jié)串,請參閱“數(shù)據(jù)類型”的第2條目

5.數(shù)據(jù)類型

1)Py3.X去除了long類型,現(xiàn)在只有一種整型——int,但它的行為就像2.X版本的long

2)新增了bytes類型,對應(yīng)于2.X版本的八位串,定義一個bytes字面量的方法如下:

>>>b=b'china'

>>>type(b)

<type'bytes'>

str對象和bytes對象可以使用.encode()(str->bytes)or.decode()(bytes->str)方法相互轉(zhuǎn)化。

>>>s=b.decode()

>>>s

'china'

>>>b1=s.encode()

>>>b1

b'china'

3)dict的.keys()、.items和.values()方法返回迭代器,而之前的iterkeys()等函數(shù)都被廢棄。同時去掉的還有

dict.has_key(),用in替代它吧

6.面向?qū)ο?/p>

1)引入抽象基類(AbstraactBaseClasses,ABCs)。

2)容器類和迭代器類被ABCs化,所以cellections模塊里的類型比Py2.5多了很多。

>>>importcollections

>>>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

另外,數(shù)值類型也被ABCs化。關(guān)于這兩點,請參閱PEP3119和PEP3141。

3)迭代器的next()方法改名為__next__(),并增加內(nèi)置函數(shù)next(),用以調(diào)用迭代器的__next__()方法

4)增加了@abstractmethod和@abstractproperty兩個decorator,編寫抽象方法(屬性)更加方便。

7.異常

1)所以異常都從BaseException繼承,并刪除了StardardError

2)去除了異常類的序列行為和.message屬性

3)用raiseException(args)代替raiseException,args語法

4)捕獲異常的語法改變,引入了as關(guān)鍵字來標識異常實例,在Py2.5中:

>>>try:

...raiseNotImplementedError('Error')

...exceptNotImplementedError,error:

...printerror.message

...

Error

在Py3.0中:

>>>try:

raiseNotImplementedError('Error')

exceptNotImplementedErroraserror:#注意這個as

print(str(error))

Error

5)異常鏈,因為__context__在3.0a1版本中沒有實現(xiàn)

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模塊(單獨發(fā)布,可以從http://www.jcea.es/programacion/pybsddb.htm獲取)

5)移除了new模塊

6)os.tmpnam()和os.tmpfile()函數(shù)被移動到tmpfile模塊下

7)tokenize模塊現(xiàn)在使用bytes工作。主要的入口點不再是generate_tokens,而是tokenize.tokenize()

9.其它

1)xrange()改名為range(),要想使用range()獲得一個list,必須顯式調(diào)用:

>>>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

()函數(shù)都被去除了

現(xiàn)在可以使用hasattr()來替換callable().hasattr()的語法如:hasattr(string,'__name__')

4)string.letters和相關(guān)的.lowercase和.uppercase被去除,請改用string.ascii_letters等

5)如果x<y的不能比較,拋出TypeError異常。2.x版本是返回偽隨機布爾值的

6)__getslice__系列成員被廢棄。a[i:j]根據(jù)上下文轉(zhuǎn)換為a.__getitem__(slice(I,j))或__setitem__和

__delitem__調(diào)用

7)file類被廢棄,在Py2.5中:

>>>file

<type'file'>

在Py3.X中:

>>>file

Traceback(mostrecentcalllast):

File"<pyshell#120>",line1,in<module>

file

NameError:name'file'isnotdefined

個人認為學習Python3比較好一些,有部分庫Python3不支持那都是常年不使用的庫而已,注意一定要確定方向是數(shù)據(jù)分析、爬蟲還是Web等等。

新手學python應(yīng)該如何選擇python2和python3

推薦python3,。

理由一:3是趨勢,學自然選新的學;

理由二:3學精通了,公司如果是使用2,問題也不大,因為同是python,同一語言不同版本而已,差距也沒那么夸張。

python2和python3的區(qū)別和python和c++學哪個好的問題分享結(jié)束啦,以上的文章解決了您的問題嗎?歡迎您下次再來哦!

返回列表
上一篇:
下一篇: