第一種方法
import sysimport unicodedatas = "Lǐ Zhōu Wú"remap = { # ord返回ascii值 ord('/t'): '', ord('/f'): '', ord('/r'): None }# 去除/t, /f, /ra = s.translate(remap)''' 通過使用dict.fromkeys() 方法構造一個字典,每個Unicode 和音符作為鍵,對于的值全部為None 然后使用unicodedata.normalize() 將原始輸入標準化為分解形式字符 sys.maxunicode : 給出最大Unicode代碼點的值的整數,即1114111(十六進制的0x10FFFF)?! nicodedata.combining:將分配給字符chr的規范組合類作為整數返回。 如果未定義組合類,則返回0。'''cmb_chrs = dict.fromkeys(c for c in range(sys.maxunicode) if unicodedata.combining(chr(c))) #此部分建議拆分開來理解b = unicodedata.normalize('NFD', a)''' 調用translate 函數刪除所有重音符'''print(b.translate(cmb_chrs))
第二種方法 (推薦)
import unicodedatamystr='Lǐ Zhōu Wú'unicodedata.normalize('NFKD', mystr).encode('ascii','ignore')
以上這篇python去除拼音聲調字母,替換為字母的方法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持武林站長站。
新聞熱點
疑難解答