本篇文章給大家談?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é)束啦,以上的文章解決了您的問題嗎?歡迎您下次再來哦!