日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關咨詢
選擇下列產品馬上在線溝通
服務時間:8:30-17:00
你可能遇到了下面的問題
關閉右側工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
創(chuàng)新互聯(lián)Python教程:python將數(shù)字轉化為漢字

本文教程操作環(huán)境:windows7系統(tǒng)、python 3.9.1,DELL G3電腦。

1、轉換思路

(1)將整數(shù)和小數(shù)分開。

(2)把四位數(shù)變成大寫漢字。

(3)把兩個小數(shù)字轉換成x角x分。

(4)重復,轉人民幣大寫。

2、實例

class cnumber:
    cdict = {}
    gdict = {}
    xdict = {}
 
    def __init__(self):
        self.cdict = {1: u'', 2: u'拾', 3: u'佰', 4: u'仟'}
        self.xdict = {1: u'元', 2: u'萬', 3: u'億', 4: u'兆'}  # 數(shù)字標識符
        self.gdict = {0: u'零', 1: u'壹', 2: u'貳', 3: u'叁', 4: u'肆', 5: u'伍', 6: u'陸', 7: u'柒', 8: u'捌', 9: u'玖'}
 
    def csplit(self, cdata):  # 拆分函數(shù),將整數(shù)字符串拆分成[億,萬,仟]的list
        g = len(cdata) % 4
        csdata = []
        lx = len(cdata) - 1
        if g > 0:
            csdata.append(cdata[0:g])
        k = g
        while k <= lx:
            csdata.append(cdata[k:k + 4])
            k += 4
        return csdata
 
    def cschange(self, cki):  # 對[億,萬,仟]的list中每個字符串分組進行大寫化再合并
        lenki = len(cki)
        i = 0
        lk = lenki
        chk = u''
        for i in range(lenki):
            if int(cki[i]) == 0:
                if i < lenki - 1:
                    if int(cki[i + 1]) != 0:
                        chk = chk + self.gdict[int(cki[i])]
            else:
                chk = chk + self.gdict[int(cki[i])] + self.cdict[lk]
            lk -= 1
        return chk
 
    def cwchange(self, data):
        cdata = str(data).split('.')
        cki = cdata[0]
        if len(cdata) == 1:
            i = 0
            chk = u''
            cski = self.csplit(cki)  # 分解字符數(shù)組[億,萬,仟]三組List:['0000','0000','0000']
            ikl = len(cski)  # 獲取拆分后的List長度
            # 大寫合并
            for i in range(ikl):
                if self.cschange(cski[i]) == '':  # 有可能一個字符串全是0的情況
                    chk = chk + self.cschange(cski[i])  # 此時不需要將數(shù)字標識符引入
                else:
                    chk = chk + self.cschange(cski[i]) + self.xdict[ikl - i]  # 合并:前字符串大寫+當前字符串大寫+標識符
            chk = chk + u'整'
        else:
            i = 0
            chk = u''
            cski = self.csplit(cki)  # 分解字符數(shù)組[億,萬,仟]三組List:['0000','0000','0000']
            ikl = len(cski)  # 獲取拆分后的List長度
            # 大寫合并
            for i in range(ikl):
                if self.cschange(cski[i]) == '':  # 有可能一個字符串全是0的情況
                    chk = chk + self.cschange(cski[i])  # 此時不需要將數(shù)字標識符引入
                else:
                    chk = chk + self.cschange(cski[i]) + self.xdict[ikl - i]  # 合并:前字符串大寫+當前字符串大寫+標識符
            # 處理小數(shù)部分
            ckj = cdata[1]
            lenkj = len(ckj)
            if lenkj == 1:  # 若小數(shù)只有1位
                if int(ckj[0]) == 0:
                    chk = chk + u'整'
                else:
                    chk = chk + self.gdict[int(ckj[0])] + u'角整'
            else:  # 若小數(shù)有兩位的四種情況
                if int(ckj[0]) == 0 and int(ckj[1]) != 0:
                    chk = chk + u'零' + self.gdict[int(ckj[1])] + u'分'
                elif int(ckj[0]) == 0 and int(ckj[1]) == 0:
                    chk = chk + u'整'
                elif int(ckj[0]) != 0 and int(ckj[1]) != 0:
                    chk = chk + self.gdict[int(ckj[0])] + u'角' + self.gdict[int(ckj[1])] + u'分'
                else:
                    chk = chk + self.gdict[int(ckj[0])] + u'角整'
        return chk
 
if __name__ == '__main__':
    pt = cnumber()
    print(pt.cwchange('14524'))  # 壹萬肆仟伍佰貳拾肆元整

以上就是python將數(shù)字轉化為漢字的方法,大家可以先就基本的轉換思路進行理解,然后在實例代碼中體會轉換的操作。更多編程基礎知識學習:python學習網(wǎng)


網(wǎng)站標題:創(chuàng)新互聯(lián)Python教程:python將數(shù)字轉化為漢字
文章出自:http://www.dlmjj.cn/article/djccsee.html