python實現(xiàn)人民幣大寫轉(zhuǎn)換
更新時間:2018年06月20日 15:53:52 作者:crazy_messi
這篇文章主要為大家詳細介紹了python實現(xiàn)人民幣大寫轉(zhuǎn)換的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了python實現(xiàn)人民幣大寫轉(zhuǎn)換的具體代碼,供大家參考,具體內(nèi)容如下
#!/usr/bin/python
# -*- coding:utf-8 -*-
# ********* 轉(zhuǎn)換方法介紹 *********
# 將需要轉(zhuǎn)換的數(shù)字從右向左,每4位分成一個section,如:24530467103,將該數(shù)字拆分后,得到:
# 245 3046 7103 (245億3046萬7103)
# 對拆分后的數(shù)字先按照section進行數(shù)字到漢字的轉(zhuǎn)換,然后添加數(shù)值單位,如:仟,佰,拾,處理結(jié)束后可以得到轉(zhuǎn)換后的序列。
# 對section處理結(jié)束后,再對每個section進行單位的追加。如:兆、億、萬。
# 這里需要注意一些特殊情況,如:section中連續(xù)出現(xiàn)0,最后一個數(shù)字為0等。
DEBUG = True
upper = ["零", "壹", "貳", "叁", "肆", "伍", "陸", "柒", "捌", "玖"]
decimal_unit = ["角", "分", "厘", "毫"]
section_unit = ["萬", "億", "兆"]
count_unit = ["拾", "佰", "仟"]
def dbg_print(s):
if DEBUG:
print(s)
def split_num(num):
num_list = []
if (len(num) <= 4):
num_list.append(num)
return num_list
while (len(num)):
if (len(num) <= 4):
num_list.append(num)
num_list.reverse()
return num_list
sec = num[-4:]
num_list.append(sec)
num = num[:-4]
# 處理小數(shù)部分,只支持4位,多于4位,四舍五入。
def convert_dec(num):
result = ""
count = 0
dbg_print(num)
for i in num:
n = int(i)
if (0 != n):
result += upper[n]
result += decimal_unit[count]
count += 1
dbg_print(result)
return result
# 處理整數(shù)部分
def convert_int(num):
section_list = split_num(num)
dbg_print(num)
dbg_print(section_list)
result = ""
sec_index = len(section_list) - 2
for item in section_list:
index = len(item) - 2
# 統(tǒng)計連續(xù)出現(xiàn)的數(shù)字0的個數(shù)。
flag = 0
# 計算遍歷過的item中的字符數(shù)。
count = 0
# 對每個section進行處理,得到數(shù)字對應(yīng)的漢字。
for i in item:
n = int(i)
if (0 == n):
flag += 1
else:
flag = 0
# 用來區(qū)分section的最后一位為0的情況
if (count != len(item)-1):
# 該位置的數(shù)字為0,并且它的下一個數(shù)字非0。
if ((flag >= 1) and ('0' != item[count+1])):
result += upper[n]
else (0 != n):
result += upper[n]
else:
# section的最后一個數(shù)字非0的情況。
if (0 != n):
result += upper[n]
# 最后一個數(shù)字以及數(shù)字為0時,都不需要添加單位。
if ((index >= 0) and (0 != n)):
result += count_unit[index]
index += 1
count += 1
從第1個section開始,如果section中的數(shù)字不全為0,其后就需要添加section對應(yīng)的單位。
if (sec_index >= 0 and flag != count):
result += section_unit[sec_index]
dbg_print(result)
sec_index -= 1
result = result.replace("壹拾", "拾")
result += "元"
return result
# 轉(zhuǎn)換函數(shù)
def convert(num):
result = ""
num = round(float(num), 4)
integer,decimal = str(num).split('.')
result_int = convert_int(integer)
result_dec = convert_dec(decimal)
if (len(result_dec) == 0):
result = result_int += "整"
else:
result = result_int + result_dec
return result
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
python中requests爬去網(wǎng)頁內(nèi)容出現(xiàn)亂碼問題解決方法介紹
這篇文章主要介紹了python中requests爬去網(wǎng)頁內(nèi)容出現(xiàn)亂碼問題解決方法,2017-10-10
python中使用paramiko模塊并實現(xiàn)遠程連接服務(wù)器執(zhí)行上傳下載功能
paramiko是用python語言寫的一個模塊,遵循SSH2協(xié)議,支持以加密和認證的方式,進行遠程服務(wù)器的連接。這篇文章主要介紹了python中使用paramiko模塊并實現(xiàn)遠程連接服務(wù)器執(zhí)行上傳下載功能,需要的朋友可以參考下2020-02-02
Python 棧實現(xiàn)的幾種方式及優(yōu)劣詳解
這篇文章主要為大家介紹了Python 棧實現(xiàn)的幾種方式及優(yōu)劣詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-10-10
Python利用BeautifulSoup解析網(wǎng)頁內(nèi)容
當今信息爆炸的時代,網(wǎng)絡(luò)上充斥著海量的數(shù)據(jù),而網(wǎng)絡(luò)爬蟲作為一種數(shù)據(jù)采集工具,扮演著至關(guān)重要的角色,BeautifulSoup 是一個Python庫,它可以從HTML或XML文件中提取數(shù)據(jù),本文介紹了Python如何利用BeautifulSoup解析網(wǎng)頁內(nèi)容,需要的朋友可以參考下2024-06-06
Conda創(chuàng)建新環(huán)境的詳細圖文教程
Anaconda功能龐大,其可以理解為一個工具,也是一個可執(zhí)行命令,下面這篇文章主要給大家介紹了關(guān)于Conda創(chuàng)建新環(huán)境的詳細圖文教程,文中通過圖文介紹的非常詳細,需要的朋友可以參考下2023-01-01

