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