正則表達(dá)式提取文本中的數(shù)字
這里演示一下文本中提取中文年份
import re
m0 = "在一九四九年新中國(guó)成立比一九九零年低百分之五點(diǎn)二人一九九六年擊敗俄軍,取得實(shí)質(zhì)獨(dú)立"
pattrern1 = '[零一二三四五六七八九]{4,}'
pattrern2 = '[〇一二三四五六七八九零壹貳叁肆伍陸柒捌玖貮兩]{4,}'
time1 = re.findall(pattrern1,m0)#轉(zhuǎn)化數(shù)字
提取年份如:‘1949', ‘1990', ‘1996'
這里給出許多正則表達(dá)式的樣例:example
中文轉(zhuǎn)化成阿拉伯?dāng)?shù)字
創(chuàng)建一個(gè)字典然后講數(shù)字進(jìn)項(xiàng)匹配:
CN_NUM = {
'〇': 0, '一': 1, '二': 2, '三': 3, '四': 4, '五': 5, '六': 6, '七': 7, '八': 8, '九': 9, '零': 0,
'壹': 1, '貳': 2, '叁': 3, '肆': 4, '伍': 5, '陸': 6, '柒': 7, '捌': 8, '玖': 9, '貮': 2, '兩': 2,}
for i in range(len(time1)):
new_str = ''
for j in time1[i]:
new_str += str(CN_NUM[j])
time1[i] = new_str
time1
這樣結(jié)果就出來(lái)啦,成功將上文例子中文年份轉(zhuǎn)化成阿拉伯?dāng)?shù)字:‘1949', ‘1990', ‘1996'
完整代碼
# 2、將句子中年份的大寫數(shù)字改為阿拉伯?dāng)?shù)字
import re
m0 = "在一九四九年新中國(guó)成立比一九九零年低百分之五點(diǎn)二人一九九六年擊敗俄軍,取得實(shí)質(zhì)獨(dú)立"
pattrern1 = '[零一二三四五六七八九]{4,}'
pattrern2 = '[〇一二三四五六七八九零壹貳叁肆伍陸柒捌玖貮兩]{4,}'
time1 = re.findall(pattrern1,m0)#轉(zhuǎn)化數(shù)字
CN_NUM = {
'〇': 0, '一': 1, '二': 2, '三': 3, '四': 4, '五': 5, '六': 6, '七': 7, '八': 8, '九': 9, '零': 0,
'壹': 1, '貳': 2, '叁': 3, '肆': 4, '伍': 5, '陸': 6, '柒': 7, '捌': 8, '玖': 9, '貮': 2, '兩': 2,}
for i in range(len(time1)):
new_str = ''
for j in time1[i]:
new_str += str(CN_NUM[j])
time1[i] = new_str
time1
總結(jié)
到此這篇關(guān)于python將中文數(shù)字轉(zhuǎn)化成阿拉伯?dāng)?shù)字的文章就介紹到這了,更多相關(guān)python中文數(shù)字轉(zhuǎn)阿拉伯?dāng)?shù)字內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
您可能感興趣的文章:- Python使用cn2an實(shí)現(xiàn)中文數(shù)字與阿拉伯?dāng)?shù)字的相互轉(zhuǎn)換
- python實(shí)現(xiàn)將中文日期轉(zhuǎn)換為數(shù)字日期
- Python實(shí)現(xiàn)中文數(shù)字轉(zhuǎn)換為阿拉伯?dāng)?shù)字的方法示例
- Python實(shí)現(xiàn)把數(shù)字轉(zhuǎn)換成中文
- python中將阿拉伯?dāng)?shù)字轉(zhuǎn)換成中文的實(shí)現(xiàn)代碼
- python數(shù)字轉(zhuǎn)對(duì)應(yīng)中文的方法總結(jié)