python實現中文數字轉阿拉伯數字

情景分析

(1) 零在中文數字串中起補位做用,處理的時候能夠忽略掉
(2) 一十一般直接縮減爲十,意味着十前獲取不到數字時爲一十
(3) 單位千、百、十前的數爲單個數字
(4) 單位萬前的數能夠由(3)複合而成
(5) 單位億前的數能夠由(3)、(4)及億自己複合而成git

代碼實現

digit = {'一': 1, '二': 2, '三': 3, '四': 4, '五': 5, '六': 6, '七': 7, '八': 8, '九': 9}
def _trans(s):
    num = 0
    if s:
        idx_q, idx_b, idx_s = s.find('千'), s.find('百'), s.find('十')
        if idx_q != -1:
            num += digit[s[idx_q - 1:idx_q]] * 1000
        if idx_b != -1:
            num += digit[s[idx_b - 1:idx_b]] * 100
        if idx_s != -1:
            # 十前忽略一的處理
            num += digit.get(s[idx_s - 1:idx_s], 1) * 10
        if s[-1] in digit:
            num += digit[s[-1]]
    return num
def trans(chn):
    chn = chn.replace('零', '')
    idx_y, idx_w = chn.rfind('億'), chn.rfind('萬')
    if idx_w < idx_y:
        idx_w = -1
    num_y, num_w = 100000000, 10000
    if idx_y != -1 and idx_w != -1:
        return trans(chn[:idx_y]) * num_y + _trans(chn[idx_y + 1:idx_w]) * num_w + _trans(chn[idx_w + 1:])
    elif idx_y != -1:
        return trans(chn[:idx_y]) * num_y + _trans(chn[idx_y + 1:])
    elif idx_w != -1:
        return _trans(chn[:idx_w]) * num_w + _trans(chn[idx_w + 1:])
    return _trans(chn)

測試例子

print(trans('十') == 10) 
print(trans('一百零一') == 101)
print(trans('九百二十一') == 921)
print(trans('五十六萬零一十') == 560010)
print(trans('一萬億零二千一百零一') == 1000000002101)
print(trans('一萬億二千一百萬零一百零一') == 1000021000101)
print(trans('一萬零二百三十億四千零七千八百九十') == 1023000007890)
相關文章
相關標籤/搜索