python 遍歷字符串(含漢字)實(shí)例詳解
python 遍歷字符串(含漢字)實(shí)例詳解
s = "中國(guó)china" for j in s: print j
首先一個(gè),你這個(gè)'a'是什么編碼?可能不是你所想的gbk
>>> a='中國(guó)' >>> a
這樣試試看,如果出來(lái)是6個(gè)字(word),說(shuō)明是utf-8,如果是4個(gè)字,說(shuō)明gbk。
另外,不管是utf-8還是gbk,都不能這樣遍歷,因?yàn)檫@里它會(huì)一個(gè)字一個(gè)字拿出來(lái)。虛擬機(jī)把a(bǔ)當(dāng)成一個(gè)長(zhǎng)度為len(a)的字符串了。
接下來(lái)是遍歷問(wèn)題。
Linux的shell大都默認(rèn)是utf-8,所以一個(gè)中文字符是三個(gè)字,所以要三個(gè)三個(gè)地讀,你可以試下:
>>> a[:3]
出來(lái)就是個(gè)”中”字
windows的command的默認(rèn)是cp936,也就是gbk,一個(gè)中文字符是兩個(gè)字,所以?xún)蓚€(gè)字兩個(gè)字地讀(a[:2])。
還有另一種遍歷的方法,把字符串轉(zhuǎn)換成unicode,這樣中文英文都是一個(gè)字,就可以用你的for i in a的方法遍歷了。這個(gè)的好處是中文英文字符都是一個(gè)字,而utf-8和gbk里,英文字母只占一個(gè)字。
s = u"中國(guó)china" for j in s: print j
輸出如下:
中 國(guó) c h i n a
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
相關(guān)文章
利用Python實(shí)現(xiàn)一鍵將頭像轉(zhuǎn)成動(dòng)漫風(fēng)
小編今天將為大家詳細(xì)介紹如何利用Python語(yǔ)言制作一個(gè)UI界面,大家可以通過(guò)一鍵點(diǎn)擊就實(shí)現(xiàn)頭像照片轉(zhuǎn)化成動(dòng)漫風(fēng)格的功能,感興趣的可以動(dòng)手嘗試一下2022-07-07
Python元類(lèi)基礎(chǔ)知識(shí)示例深度剖析
這篇文章主要為大家介紹了Python元類(lèi)基礎(chǔ)知識(shí)深度剖析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-06-06
使用Python 自動(dòng)生成 Word 文檔的教程
今天小編就為大家分享一篇使用Python 自動(dòng)生成 Word 文檔的教程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-02-02
python3中set(集合)的語(yǔ)法總結(jié)分享
這篇文章主要總結(jié)了關(guān)于python3中set(集合)的語(yǔ)法的相關(guān)資料,文中給出了詳細(xì)的示例代碼,對(duì)大家具有一定的參考價(jià)值,需要的朋友們下面來(lái)一起看看吧。2017-03-03
基于python編寫(xiě)監(jiān)控系統(tǒng)各項(xiàng)資源的腳本
這篇文章主要為大家詳細(xì)介紹了如何編寫(xiě)一個(gè)python腳本,實(shí)現(xiàn)監(jiān)控網(wǎng)絡(luò)的流量、CPU使用率、內(nèi)存使用率和磁盤(pán)使用情況,感興趣的小伙伴可以了解下2023-11-11
Python中pandas庫(kù)的常用操作實(shí)例
這篇文章主要介紹了Python中pandas庫(kù)的常用操作實(shí)例,Pandas 庫(kù)是一個(gè)免費(fèi)、開(kāi)源的第三方 Python 庫(kù),是 Python 數(shù)據(jù)分析必不可少的工具之一,它為 Python 數(shù)據(jù)分析提供了高性能,且易于使用的數(shù)據(jù)結(jié)構(gòu),即 Series 和 DataFrame,需要的朋友可以參考下2023-07-07

