首先兩者的差別不大,最明顯的區別在于調用PRint的方式,我們根據這就可一眼區分出2x還是3x版本,最重要的區別則是處理Unicode字符的方式。
一、 print 從語句變為函數原: print 1, 2+3改為: print ( 1, 2+3 )二、range 與 xrange原 : range( 0, 4 ) 結果 是 列表 [0,1,2,3 ]改為:list( range(0,4) )原 : xrange( 0, 4 ) 適用于 for 循環的變量控制改為:range(0,4)三、字符串原: 字符串以 8-bit 字符串存儲改為: 字符串以 16-bit Unicode 字符串存儲Py3.X源碼文件默認使用utf-8編碼,這就使得以下代碼是合法的: >>> 中國 = 'china' >>>print(中國) china 四、try except 語句的變化原: try: ...... except Exception, e : ......改為 try: ...... except Exception as e : ......五、打開文件原: file( ..... ) 或 open(.....)改為: 只能用 open(.....)六、從鍵盤錄入一個字符串原: raw_input( "提示信息" )改為: input( "提示信息" )七:除法運算符python 2.4.2以前 10/3 結果為 3 python 3.0 10 / 3 結果為 3.3333333333333335 10 // 3 結果為 3八、字節數組對象 --- 新增(一) 初始化 a = bytearray( 10 ) # a 是一個由十個字節組成的數組,其每個元素是一個字節,類型借用 int # 此時,每個元素初始值為 0(二) 字節數組 是可變的 a = bytearray( 10 ) a[0] = 25 # 可以用賦值語句更改其元素,但所賦的值必須在 0 ~ 255 之間(三) 字節數組的切片仍是字節數組(四) 字符串轉化為字節數組 #coding=gbk s ="你好" b = s.encode( "gbk") # 先將字符串按某種“GBK”編碼方式轉化為 bytes c = bytearray( b ) #再將 bytes 轉化為 字節數組 也可以寫作 c = bytearray( "你好", "gbk")(五) 字節數組轉化為字符串 c = bytearray( 4 ) c[0] = 65 ; c[1]=66; c[2]= 67; c[3]= 68 s = c.decode( "gbk" ) print ( s ) # 應顯示: ABCD (六) 字節數組可用于寫入文本文件#coding=gbkf = open("c://1234.txt", "wb")s = "張三李四abcd1234"# -------------------------------# 在 python2.4 中我們可以這樣寫:# f.write( s )# 但在 python 3.0中會引發異常# -------------------------------b = s.encode("gbk")f.write( b )c=bytearray( "王五","gbk")f.write( c )f.close()input("?")bytes 可以看成是“字節數組”對象,每個元素是 8-bit 的字節,取值范圍 0~255。
由于在 python 3.0中字符串以 unicode 編碼存儲,當寫入二進制文件時,字符串無法直接寫入(或讀?。?,必須以某種方式的編碼為字節序列后,方可寫入。
(一)字符串編碼(encode) 為 bytes例: s = "張三abc12" b = s.encode( 編碼方式) # b 就是 bytes 類型的數據 # 常用的編碼方式為 : "uft-16" , "utf-8", "gbk", "gb2312", "ascii" , "latin1" 等 # 注 : 當字符串不能編碼為指定的“編碼方式”時,會引發異常(二) bytes 解碼(decode)為字符串 s = "張三abc12" b = s.encode( "gbk") # 字符串 s 編碼為 gbk 格式的字節序列 s1 = b.decode("gbk") # 將字節序列 b以gbk格式 解碼為字符串 # 說明,當字節序列不能以指定的編碼格式解碼時會引發異常(三)使用方法舉例#coding=gbkf = open("c://1234.txt", "wb")s = "張三李四abcd1234"# -------------------------------# 在 python2.4 中我們可以這樣寫:# f.write( s )# 但在 python 3.0中會引發異常# -------------------------------b = s.encode("gbk")f.write( b )f.close()input("?")讀取該文件的例子:#coding=gbkf = open("c://1234.txt", "rb")f.seek(0,2) #定位至文件尾n = f.tell() #讀取文件的字節數f.seek(0,0) #重新定位至文件開始處b = f.read( n )# ------------------------------# 在 python 2.4 中 b 是字符串類型# 要 python 3.0 中 b 是 bytes 類型# 因此需要按指定的編碼方式確碼# ------------------------------ s = b.decode("gbk")print ( s )# ------------------------------# 在 python 2.4 中 可以寫作 print s 或 print ( s )# 要 python 3.0 中 必須寫作 print ( s )# ------------------------------ f.close()input("?")運行后應顯示:張三李四abcd1234(四) bytes序列,一但形成,其內容是不可變的例:s="ABCD"b=s.encode("gbk")print b[0] # 顯示 65b[0] = 66 # 執行該句,出現異常: 'bytes' object does not support item assignment另(歸納補充): 1:“import thread”問題,python2x中的模塊thread在python3x中編程”_thread”(需要在前面加一個下劃線).否則會出現“ImportError: No module named thread 2、range():python2中返回一個列表,python3中返回一個自然數序列 3、Python3x中的字符串是Unicode字符串而不是字節數組,而在Python2x中,我們需要區分普通的以字節為單位的字符串以及Unicode字符串。 4、 python2x里keys()會返回一個列表,也就是對一個字典a,a.keys()返回的就是a的所有的鍵組成的一個列表 而在python3x里,a.keys()返回的是dict_keys()形式,它是鍵的迭代形式,譬如: a={‘redkey’:’redvalue’,’yellowkey’:’yellowvalue’,’bluekey’:’bluevalue’} a.keys() 就是: dict_keys([‘redkey’,’yellowkey’,’bluekey’]) 想要使用它就需要我們把它轉換成list形式: list(a.keys()) 就是: [‘redkey’,’yellowkey’,’bluekey’] 同樣,對于python3x中的values()以及items()也需要我們手動把其返回值變為列表形式
新聞熱點
疑難解答