python3與python2.7的分別
搜尋一下大家就會知道,python有兩個主要的版本,python2 和python3 ,但是python又不同於其他語言,向下兼容,python3是不向下兼容的,但是絕大多數組件和擴展都是基於python2的,下面就來總結一下python2和python3的差別。
1.性能
Py3.0運行 pystone benchmark的速度比Py2.5慢30%。 Guido認為Py3.0有極大的最佳化空間,可在字串和整形操作上
以獲得良好的最佳化結果。
Py3.1表現比Py2.5慢15%,還有很大的進步空間。
2.編碼
Py3.X原始碼檔案預設使用utf-8編碼,這使得下列程式碼是合法的:
>>> 中國= '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
print "The answer is", 2*22)
2.X: print x, # 使用空格取代換行
2.X: print 3.X: print() # 輸出新行中
遠fatal error", file=sys.stderr)
2 .X: print (x, y) # 輸出repr((x, y))
# 不同於print(x, y)! 7)改變了順序運算元的行為,例如x
3.X這樣:
>>> 0666
SyntaxError: invalid token (
>>> 0o666
438
11)增加了2進製字面量和bin()函數 >>> bin(438) '0b110110110' >>> _438 = '0b1101111>>> _438 = '0b1101110110'430110' '0b110110110'
12)擴充的可迭代解包。在Py3.X 裡,a, b, *rest = seq和 *rest, a = seq都是合法的,只要求兩點:rest是list
物件和seq是可迭代的。
13)新的super(),可以不再給super()傳遞參數,
>>> class C(object):
def __in
def __in
print('C', a )
>>> class D(C):
def __init(self, a):
super().__init__(a) # 無參數呼叫super()
>>> D(8)
14)新的metaclass語法: class Foo(*bases, **kwds): pass 15)支援class decorator。用法與函數decorator相同: >>> def foo(cls_a): def print_func(self): cls_a.print = print_func
return cls_a
> >> @foo
class C(object):
pass
>>> C().print() 更多請參閱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)
str物件和bytes物件可以使用.encode() (str -> bytes) or .destr() (bytes> str相互轉化。
>>> s = b.decode()
>>> s
'china'
>>> b1 = 'china'
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姆姆 ItemsView
Iterable
Iterator
KeysView
MapMap
MappingView
MutableMapping
MutableSequence
MutableSetp Set
Sized
ValuesView
__all__
__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 . except NotImplementedError, error: ... print error.message ... >>> try:raise NotImplementedError('Error')
except NotImplementedError as error: #留意這個as Error
5)異常鏈,因為__context__在3.0a1版本中沒有實作
8.模組變動
1)移除了cPickle模組,可以使用pickle模組代替。最終我們將會有一個透明且有效率的模組。
2)移除了imageop模組
3)移除了audiodev, Bastion, bsddb185, exceptions, linuxaudiodev, md5, MimeWriter, mimify, popen2, linuxaudiodev, md5, MimeWriter, mimify, popen2, properion
frex, min.m. xmllib模組 4)移除了bsddb模組(單獨發布,可以從http://www.jcea.es/programacion/pybsddb.htm取得) 5)移除了new模組 6)os.tmpmp ()和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' ntr f')和b.split(b' ')來達到相同目的 3 )zip()、map()和filter()都回傳迭代器。而apply()、 callable()、coerce()、 execfile()、reduce()和reload ()函數都被去除了 現在可以使用hasattr()來取代callable().的語法如:hasattr(string, '__name__') 4)string.letters和相關的.lowercase和.uppercase被去除,請改用string.ascii_letters 等 5)如果x 6)__getslice__系列成員被廢棄。 a[i:j]依上下文轉換為a.__getitem__(slice(I, j))或__setitem__和 __delitem__調用 7)file類別被廢棄,在Py2.5: >> > file

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

PHP和Python各有優劣,選擇取決於項目需求和個人偏好。 1.PHP適合快速開發和維護大型Web應用。 2.Python在數據科學和機器學習領域佔據主導地位。

在CentOS系統上啟用PyTorchGPU加速,需要安裝CUDA、cuDNN以及PyTorch的GPU版本。以下步驟將引導您完成這一過程:CUDA和cuDNN安裝確定CUDA版本兼容性:使用nvidia-smi命令查看您的NVIDIA顯卡支持的CUDA版本。例如,您的MX450顯卡可能支持CUDA11.1或更高版本。下載並安裝CUDAToolkit:訪問NVIDIACUDAToolkit官網,根據您顯卡支持的最高CUDA版本下載並安裝相應的版本。安裝cuDNN庫:前

Docker利用Linux內核特性,提供高效、隔離的應用運行環境。其工作原理如下:1. 鏡像作為只讀模板,包含運行應用所需的一切;2. 聯合文件系統(UnionFS)層疊多個文件系統,只存儲差異部分,節省空間並加快速度;3. 守護進程管理鏡像和容器,客戶端用於交互;4. Namespaces和cgroups實現容器隔離和資源限制;5. 多種網絡模式支持容器互聯。理解這些核心概念,才能更好地利用Docker。

Python和JavaScript在社區、庫和資源方面的對比各有優劣。 1)Python社區友好,適合初學者,但前端開發資源不如JavaScript豐富。 2)Python在數據科學和機器學習庫方面強大,JavaScript則在前端開發庫和框架上更勝一籌。 3)兩者的學習資源都豐富,但Python適合從官方文檔開始,JavaScript則以MDNWebDocs為佳。選擇應基於項目需求和個人興趣。

MinIO對象存儲:CentOS系統下的高性能部署MinIO是一款基於Go語言開發的高性能、分佈式對象存儲系統,與AmazonS3兼容。它支持多種客戶端語言,包括Java、Python、JavaScript和Go。本文將簡要介紹MinIO在CentOS系統上的安裝和兼容性。 CentOS版本兼容性MinIO已在多個CentOS版本上得到驗證,包括但不限於:CentOS7.9:提供完整的安裝指南,涵蓋集群配置、環境準備、配置文件設置、磁盤分區以及MinI

在CentOS系統上進行PyTorch分佈式訓練,需要按照以下步驟操作:PyTorch安裝:前提是CentOS系統已安裝Python和pip。根據您的CUDA版本,從PyTorch官網獲取合適的安裝命令。對於僅需CPU的訓練,可以使用以下命令:pipinstalltorchtorchvisiontorchaudio如需GPU支持,請確保已安裝對應版本的CUDA和cuDNN,並使用相應的PyTorch版本進行安裝。分佈式環境配置:分佈式訓練通常需要多台機器或單機多GPU。所

在CentOS系統上安裝PyTorch,需要仔細選擇合適的版本,並考慮以下幾個關鍵因素:一、系統環境兼容性:操作系統:建議使用CentOS7或更高版本。 CUDA與cuDNN:PyTorch版本與CUDA版本密切相關。例如,PyTorch1.9.0需要CUDA11.1,而PyTorch2.0.1則需要CUDA11.3。 cuDNN版本也必須與CUDA版本匹配。選擇PyTorch版本前,務必確認已安裝兼容的CUDA和cuDNN版本。 Python版本:PyTorch官方支

CentOS 安裝 Nginx 需要遵循以下步驟:安裝依賴包,如開發工具、pcre-devel 和 openssl-devel。下載 Nginx 源碼包,解壓後編譯安裝,並指定安裝路徑為 /usr/local/nginx。創建 Nginx 用戶和用戶組,並設置權限。修改配置文件 nginx.conf,配置監聽端口和域名/IP 地址。啟動 Nginx 服務。需要注意常見的錯誤,如依賴問題、端口衝突和配置文件錯誤。性能優化需要根據具體情況調整,如開啟緩存和調整 worker 進程數量。
