python人民币小写转大写辅助工具

这篇文章主要为大家详细介绍了python人民币小写转大写辅助工具,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了python人民币大小写转换的具体代码,供大家参考,具体内容如下

大家应该都知道,银行打印账单有时候会跟上人民币的阿拉伯数字以及人民币汉字大写写法,转换的过程中有一定的逻辑难度,较为麻烦,所以笔者心血来潮,花了点时间简单实现了一下这一转换过程,以供初学者参考。

输入样例:

123.22

输出样例:

壹佰贰拾叁圆贰角贰分

参考代码

#!/usr/bin/env python # encoding: utf-8 from __future__ import print_function import sys import re import base64 import time import os import getpass reload(sys) sys.setdefaultencoding("utf-8") char_arr_01 = [u"零".decode("utf8"), u"壹".decode("utf8"), u"贰".decode("utf8"), u"叁".decode("utf8"), u"肆".decode( "utf8"), u"伍".decode("utf8"), u"陆".decode("utf8"), u"柒".decode("utf8"), u"捌".decode("utf8"), u"玖".decode("utf8")]; char_arr_02 = [u"圆".decode("utf8"), u"拾".decode("utf8"), u"佰".decode("utf8"), u"仟".decode("utf8"), u"万".decode("utf8"), u"拾".decode("utf8"), u"佰".decode("utf8"), u"仟".decode( "utf8"), u"亿".decode("utf8"), u"拾".decode("utf8"), u"佰".decode("utf8"), u"仟".decode("utf8"), u"万".decode("utf8"), u"拾".decode("utf8"), u"佰".decode("utf8")] char_arr_03 = [u"分".decode("utf8"), u"角".decode("utf8")] def calcRMB(): sum_arr = [] in_str_dot = "" in_str_Big = "" flag = 0 dot_count = 0 in_str = raw_input("Please input number : ") for i in in_str: if i == '.': dot_count += 1 elif ord(i) = ord('A'): print("Error") return if len(in_str) > 12 or dot_count > 1: print("Error") return in_str = unicode(in_str).decode("utf8") out_str = "" if in_str.find('.') != -1: flag = 1 sum_arr = in_str.split('.') in_str_Big = sum_arr[0] if flag==1: in_str_dot = sum_arr[1] for i in range(len(in_str_Big)): if cmp(in_str_Big[i],'0') == 0 and (len(in_str_Big)-1-i)%4 != 0: out_str = out_str + char_arr_01[ord(in_str_Big[i])-ord('0')] else: out_str = out_str + char_arr_01[ord(in_str_Big[i])-ord('0')] out_str = out_str + char_arr_02[len(in_str_Big)-1-i] while out_str.find(u"零零".decode("utf8")) != -1: out_str = out_str.replace(u"零零".decode("utf8"), u"零".decode("utf8")) out_str = out_str.replace(u"零亿".decode("utf8"),u"亿".decode("utf8")) out_str = out_str.replace(u"零万".decode("utf8"),u"万".decode("utf8")) if out_str != u"零元".decode("utf8"): out_str = out_str.replace(u"零圆".decode("utf8"),u"圆".decode("utf8")) if len(in_str_dot) > 2 and flag == 1: print("False !!") return if flag == 1: for i in range(len(in_str_dot)): out_str = out_str + char_arr_01[ord(in_str_dot[i])-ord('0')] out_str = out_str + char_arr_03[len(in_str_dot)-1-i] print(out_str) def main(): while 1: os.system("cls") calcRMB() print() end_flag = raw_input("Try Again ? (y/n)") if end_flag == 'y' or end_flag == 'Y': continue elif end_flag == 'n' or end_flag == 'N': break else: print("nError!!") break if __name__ == '__main__': main()

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

相关文章

功能概要:(目前已实现功能)公共展示部分:1.网站首页展示...
大体上把Python中的数据类型分为如下几类: Number(数字) ...
开发之前第一步,就是构造整个的项目结构。这就好比作一幅画...
源码编译方式安装Apache首先下载Apache源码压缩包,地址为ht...
前面说完了此项目的创建及数据模型设计的过程。如果未看过,...
python中常用的写爬虫的库有urllib2、requests,对于大多数比...