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