Python使用cn2an實現中文數字與阿拉伯數字的相互轉換
工作中經常遇到阿拉伯數字轉換稱為中文數字或者大寫金額,在網上搜了下,cn2an口碑較好,遂進行了一番學習。
安裝pip install cn2an
依賴庫為setuptools、PyYAML
查看版本In [1]: import cn2anIn [2]: cn2an.__version__Out[2]: ’0.5.8’查看模塊定義的標識符
In [3]: dir(cn2an)Out[3]:[’An2Cn’, ’Cn2An’, ’Transform’, ’__all__’, ’__builtins__’, ’__cached__’, ’__doc__’, ’__file__’, ’__loader__’, ’__name__’, ’__package__’, ’__path__’, ’__spec__’, ’__version__’, ’an2cn’, ’cn2an’, ’transform’, ’utils’]模塊結構
cn2an模塊結構如下:
an2cn.pyan2cn_test.pycn2an.pycn2an_test.pyconfig.yamlperformance.pytransform.pytransform_test.pyutils.py__init__.py
查看模塊下的__init__.py文件可知,模塊主要對外暴露cn2an、an2cn和transform三個方法。
from .cn2an import Cn2Anfrom .an2cn import An2Cnfrom .transform import Transform__version__ = '0.5.8'cn2an = Cn2An().cn2anan2cn = An2Cn().an2cntransform = Transform().transform__all__ = [ '__version__', 'cn2an', 'an2cn', 'transform']使用說明1. 中文數字轉阿拉伯數字
In [4]: help(cn2an.cn2an)Help on method cn2an in module cn2an.cn2an:cn2an(inputs: str = None, mode: str = ’strict’) -> int method of cn2an.cn2an.Cn2An instance
查看幫助可知:cn2an方法有兩個參數:inputs和mode,inputs類型為字符串,默認值為空值,mode類型為字符串,默認值為strict,查看源碼可知,mode僅支持strict, normal, smart等三個值。返回值為int類型。最大支持到10**16,即 千萬億,最小支持到 10**-16。
1.1 嚴格模式(strict)
默認為嚴格模式,嚴格模式下只有嚴格符合數字拼寫的才可以進行轉化。
In [1]: import cn2anIn [2]: output = cn2an.cn2an('一百二十三')In [3]: outputOut[3]: 123In [4]: output = cn2an.cn2an('一二三')---------------------------------------------------------------------------ValueErrorTraceback (most recent call last)<ipython-input-4-4c55ae4aa4a9> in <module>----> 1 output = cn2an.cn2an('一二三')c:usersadministratorappdatalocalprogramspythonpython37libsite-packagescn2ancn2an.py in cn2an(self, inputs, mode) 30 31 # 檢查輸入數據是否有效---> 32 sign, integer_data, decimal_data, is_all_num = self.__check_input_data_is_valid(inputs, mode) 33 34 # smart 下的特殊情況c:usersadministratorappdatalocalprogramspythonpython37libsite-packagescn2ancn2an.py in __check_input_data_is_valid(self, check_data, mode) 155 else: 156 if mode == 'strict':--> 157 raise ValueError(f'不符合格式的數據:{integer_data}') 158 elif mode == 'normal': 159 # 純數模式:一二三ValueError: 不符合格式的數據:一二三
1.2 正常模式(normal)
在正常模式下,可以對 一二三 進行轉化
In [5]: output = cn2an.cn2an('一二三',’normal’)In [6]: outputOut[6]: 123
1.3 靈活模式(smart)
在 靈活模式下,可以對混合拼寫的 1百23 進行轉換,也可以對口語化數字進行轉換
In [7]: output = cn2an.cn2an('1百23', 'smart')In [8]: outputOut[8]: 123In [9]: output = cn2an.cn2an('一萬二', 'smart')In [10]: outputOut[10]: 120002. 阿拉伯數字轉中文數字
In [1]: import cn2anIn [2]: help(cn2an.an2cn)Help on method an2cn in module cn2an.an2cn:an2cn(inputs: Union[str, int, float] = None, mode: str = ’low’) -> str method of cn2an.an2cn.An2Cn instance 阿拉伯數字轉中文數字 :param inputs: 阿拉伯數字 :param mode: 小寫數字,大寫數字,人民幣大寫,直接轉化 :return: 中文數字
查看幫助可知:
an2cn方法有兩個參數:inputs和mode,inputs類型可以是字符串、整數或者浮點數,默認值為空值,mode類型為字符串,默認值為low,查看源碼可知,mode支持low, up, rmb, direct等四個值。返回值為str類型。
2.1 小寫中文模式(low)
在 low 模式(默認)下,數字轉化為小寫的中文數字。
In [3]: output = cn2an.an2cn('123')In [4]: outputOut[4]: ’一百二十三’In [5]: output = cn2an.an2cn('123', 'low')In [6]: outputOut[6]: ’一百二十三’
2.2 大寫中文模式(up)
在 up 模式下,數字轉化為大寫的中文數字。
In [7]: output = cn2an.an2cn('123', 'up')In [8]: outputOut[8]: ’壹佰貳拾叁’
2.3 人民幣模式(rmb)
在 rmb 模式下,數字轉化為人民幣專用的描述。
In [9]: output = cn2an.an2cn('123', 'rmb')In [10]: outputOut[10]: ’壹佰貳拾叁元整’
2.4 直接模式(direct)
在 direct 模式下,阿拉伯數字直接轉換為對應的中文小寫數字,小數點轉換為漢字點。
In [11]: output = cn2an.an2cn('-1.23', 'direct')In [12]: outputOut[12]: ’負一點二三’3. 句子中的數字轉換
文檔中說明該功能為實驗性質,功能尚不穩定。
In [1]: import cn2anIn [2]: help(cn2an.transform)Help on method transform in module cn2an.transform:transform(inputs: str, method: str = ’cn2an’) -> str method of cn2an.transform.Transform instance
transform方法具有兩個參數:inputs和method,inputs的類型為字符串,method的類型為字符串,默認值為cn2an,查看源碼可知method支持cn2an和an2cn這兩個值。返回值為字符串。
3.1 中文數字轉阿拉伯數字
在 cn2an 方法(默認)下,可以將句子中的中文數字轉換為阿拉伯數字查看源碼可知默認情況下,中文數字轉換阿拉伯數字采用的smart模式。
In [3]: output = cn2an.transform('小王撿了一百塊錢')In [4]: outputOut[4]: ’小王撿了100塊錢’In [5]: output = cn2an.transform('整齊的步伐,一二一')In [6]: outputOut[6]: ’整齊的步伐,121’
transform方法會根據正則表達式,檢測日期、攝氏度、分數、百分比等特殊情況進行轉換。
In [7]: output = cn2an.transform('小王的生日是二零零一年三月四日', 'cn2an')In [8]: outputOut[8]: ’小王的生日是2001年3月4日’In [9]: output = cn2an.transform('拋出去的硬幣為正面的概率是二分之一', 'cn2an')In [10]: outputOut[10]: ’拋出去的硬幣為正面的概率是1/2’In [11]: output = cn2an.transform('任務已經完成百分之五十', 'cn2an')In [12]: outputOut[12]: ’任務已經完成50%’In [13]: output = cn2an.transform('明天最低溫度一度', 'cn2an')In [14]: outputOut[14]: ’明天最低溫度1度’In [15]: output = cn2an.transform('明天最低溫度一攝氏度', 'cn2an')In [16]: outputOut[16]: ’明天最低溫度1℃’
3.2 阿拉伯數字轉中文數字
在an2cn 方法下,可以將句子中的阿拉伯數字轉換為中文數字。an2cn 模式下,依然會檢測日期、攝氏度、分數、百分比等特殊情況進行轉換
In [2]: output = cn2an.transform('小王撿了100塊錢', 'an2cn')In [3]: outputOut[3]: ’小王撿了一百塊錢’In [4]: output = cn2an.transform('金額為12000元 ', 'an2cn')In [5]: outputOut[5]: ’金額為一萬二千元 ’In [6]: output = cn2an.transform('小王的生日是2001年3月4日', 'an2cn')In [7]: outputOut[7]: ’小王的生日是二零零一年三月四日’In [8]: output = cn2an.transform('拋出去的硬幣為正面的概率是1/2', 'an2cn')In [9]: outputOut[9]: ’拋出去的硬幣為正面的概率是二分之一’In [10]: output = cn2an.transform('任務完成了50%', 'an2cn')In [11]: outputOut[11]: ’任務完成了百分之五十’In [12]: output = cn2an.transform('今天最低氣溫1攝氏度', 'an2cn')In [13]: outputOut[13]: ’今天最低氣溫一攝氏度’
3.3 問題(大寫數字)
根據源碼可知transform方法優先考慮日期、分數、百分比、攝氏度等情況判斷,不符合這幾種情況的都判斷為普通數字,因此,大寫數字在transform方法中表現并不好!
In [14]: output = cn2an.transform('金額為壹萬貳仟元', 'cn2an')WARN: 不符合格式的數據:萬WARN: 不符合格式的數據:仟In [15]: outputOut[15]: ’金額為壹萬貳仟元 ’
測試
cn2an提供了web demo進行體驗。https://www.dovolopor.com/cn2an
API
cn2an提供了API,支持Java、Javascript、Go、Julia、Python等。https://github.com/Ailln/cn2an/wiki/API#http-api
到此這篇關于Python使用cn2an實現中文數字與阿拉伯數字的相互轉換的文章就介紹到這了,更多相關Python 中文數字與阿拉伯數字轉換內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!
相關文章:
