字串還有乙個編碼問題。
因為計算機只能處理數字,如果要處理文字,就必須先把文字轉換為數字才能處理。最早的計算機在設計時採用8個位元(bit)作為乙個位元組 (byte),所以,乙個位元組能表示的最大的整數就是255(二進位制11111111=十進位制255),0 - 255被用來表示大小寫英文本母、數字和一些符號,這個編碼表被稱為ascii編碼,比如大寫字母 a 的編碼是65,小寫字母 z 的編碼是122。
如果要表示中文,顯然乙個位元組是不夠的,至少需要兩個位元組,而且還不能和ascii編碼衝突,所以,中國制定了gb2312編碼,用來把中文編進去。
類似的,日文和韓文等其他語言也有這個問題。為了統一所有文字的編碼,unicode應運而生。unicode把所有語言都統一到一套編碼裡,這樣就不會再有亂碼問題了。
unicode通常用兩個位元組表示乙個字元,原有的英文編碼從單位元組變成雙位元組,只需要把高位元組全部填為0就可以。
因為python的誕生比unicode標準發布的時間還要早,所以最早的python只支援ascii編碼,普通的字串'abc'在python內部都是ascii編碼的。
python在後來新增了對unicode的支援,以unicode表示的字串用u'...'表示,比如:
print u'中文'注意:不加 u ,中文就不能正常顯示。中文
unicode字串除了多了乙個u
之外,與普通字串沒啥區別,轉義字元和多行表示法仍然有效:
轉義:
u'中文\n日文\n韓文'多行:
u'''第一行raw+多行:第二行'''
ur'''python的unicode字串支援"中文",如果中文字串在python環境下遇到 unicodedecodeerror,這是因為.py檔案儲存的格式有問題。可以在第一行新增注釋"日文",
"韓文"等多種語言'''
# -*- coding: utf-8 -*-目的是告訴python直譯器,用utf-8編碼讀取源**。然後用notepad++ 另存為... 並選擇utf-8格式儲存。
用多行unicode字串表示下面的唐詩並列印:
靜夜思床前明月光,
疑是地上霜。
舉頭望明月,
低頭思故鄉。
# -*- coding: utf-8 -*-
print u'''靜夜思
床前明月光,
疑是地上霜。
舉頭望明月,
低頭思故鄉。'''
python中string和Unicode的區別
首先要弄清楚的是,在python裡,string object和unicode object是兩種不同的型別。string object是由characters組成的sequence,而unicode object是unicode code units組成的sequence。string裡的char...
Python入門基礎(二)
內容導航 1.列表,元組操作 2 字典操作 3.檔案操作 1.列表,元組操作 列表的建立 names marry jane kangkang lisa print names print names 0 通過下標訪問列表中的元素,下標從0開始計數 print names 1 代表最後乙個元素 for...
Python爬蟲入門 二
爬蟲,即網路爬蟲,大家可以理解為在網路上爬行的一直蜘蛛,網際網路就比作一張大網,而爬蟲便是在這張網上爬來爬去的蜘蛛咯,如果它遇到資源,那麼它就會抓取下來。想抓取什麼?這個由你來控制它咯。比如它在抓取乙個網頁,在這個網中他發現了一條道路,其實就是指向網頁的超連結,那麼它就可以爬到另一張網上來獲取資料。...