本文實例講述了Python正則表達式匹配中文用法。分享給大家供大家參考,具體如下:
#!/usr/bin/python#-*- coding:cp936-*-#思路,將str轉換成unicode,方可用正則表達式,前提是,要知道文件的編碼,本例中是gbkimport cPickle as mypickleimport reimport sysif (__name__=='__main__'): fid1=file('demo.txt','r');#demo.txt寫入字符如:武林站長站 p=re.compile('(^/s+|/s+$)'); phanzigbk=re.compile('[//x20-//x7f]'); phanzi=re.compile(u'[/u4e00-/u9fa5]');#這里要加u,注意 commlines=fid1.readlines(); fid1.close(); dictfamilyname={}; dictfirstname={}; for line in commlines: line=p.sub('',line); print type(line); print line; uline=unicode(line,'gbk'); print type(uline); candidates=phanzi.findall(uline); print len(candidates); if(len(candidates)==2): print candidates[0]; familynamegbk=candidates[0].encode('gbk');#把unicode型的變量變成str型的變量 firstnamegbk=candidates[1].encode('gbk'); if(dictfamilyname.has_key(familynamegbk)): dictfamilyname[familynamegbk]=dictfamilyname[familynamegbk]+1; else: dictfamilyname[familynamegbk]=1; if(dictfirstname.has_key(firstnamegbk)): dictfirstname[firstnamegbk]=dictfirstname[firstnamegbk]+1; else: dictfirstname[firstnamegbk]=1; familynameitems=dictfamilyname.items(); print familynameitems; firstnameitems=dictfirstname.items(); familynameitems.sort(key=lambda d:d[1],reverse=True); firstnameitems.sort(key=lambda d :d[1],reverse=True); fid=file('familyname.txt','w'); for m in familynameitems: s=m[0]+'/t'+str(m[1]); fid.write(s); fid.write('/n'); fid.close(); fid=file('firstname.txt','w'); for m in firstnameitems: s=m[0]+'/t'+str(m[1]); fid.write(s); fid.write('/n'); fid.close(); print 'finish'
運行效果圖如下:
PS:這里再為大家提供2款非常方便的正則表達式工具供大家參考使用:
JavaScript正則表達式在線測試工具:
http://tools.jb51.net/regex/javascript
正則表達式在線生成工具:
http://tools.jb51.net/regex/create_reg
更多關于Python相關內容可查看本站專題:《Python正則表達式用法總結》、《Python數據結構與算法教程》、《Python Socket編程技巧總結》、《Python函數使用技巧總結》、《Python字符串操作技巧匯總》、《Python入門與進階經典教程》及《Python文件與目錄操作技巧匯總》
希望本文所述對大家Python程序設計有所幫助。
新聞熱點
疑難解答