百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

分享一个用python实现算法的样例程序-阿拉伯数字转换为中文数字

off999 2024-11-01 12:51 27 浏览 0 评论

根据《算法的乐趣》提供的思路,用python2编写了一个程序来实现转换的过程,对算法逻辑做了说明,并且程序每个步骤都有注释,提供统一格式的日志输出,方便理解算法过程。

分享一下:

#!/usr/bin/python
# -*- coding: utf-8 -*-
'''
脚本功能:阿拉伯数字与中文数字转换
输入参数:阿拉伯数字,不带符号 
说明:根据《算法的乐趣》提供的算法
中文数字的权位和小节 
中文数字的特点之一就是每个计数数字都跟着一个权位,这个权位就是数字的量值,相当于阿拉伯数字中的数位。最低位(个位)没有权位,也可以理解为权位为空 
中文数字的另一个特点是以“万”为小节(欧美习惯以“千”为小节),每一个小节都有一个节权位,万以下的没有节权位(或节权位为空),万以上的就是万,再大的就是“亿”,每个小节内部都以“十百千”为权位的独立计数。“十百千”这几个权位是不能连续出现的,如二十百,一千千,但万和亿作为节权位却可以和其他权位一起使用,如二十亿等
中文数字的零 
中文对零的使用总结有以下三条: 
规则1:以10000为小节,小节的结尾即使是0,也不使用“零”。 
规则2:小节内两个非0数字之间要使用“零”。 
规则3:当小节的“千”为是0是,若本小节的前一小节无其他数字,则不用“零”,否则用“零”。
这里蕴含的算法设计模式 我觉得有 分治法 动态规划(状态位)
'''
import os
import sys
import logging
import math
#首先定义对照关系元组
#CHN_NUM_CHAR_COUNT = 10
#单个数字对应的中文汉字
chnNumChar = ("零", "壹", "贰", "叁", "肆", "伍", "陆", "柒", "捌", "玖")
#小节位,对32位正数表达的最大整数来说,最大节权万亿就够了
chnUnitSetion = ("", "万", "亿", "万亿")
#每个小节里面的独立计数
chnUnitChar = ("", "拾", "佰", "仟")
def NumberToChinese(num):
    #取每个小节内数据然后节内处理
    #先定义小节的位置,从最低一级的小节开始转换
    unitPos=0
    #定义规则3需不需要补零的状态位,初始默认是不需要补零
    needZero=False
    #初始字符串
    chnStr=""
    while num > 0 :
        strIns=""
        section=num % 10000
        logging.debug( "Now:num: "+str(num) +"section:"+str(section))
        if needZero:
            #满足规则3需要添零,根据后面的语句是否修改了needZero来检测是否添加0
            chnStr=chnNumChar[0]+chnStr
            logging.debug( "Now:chnStr:"+chnStr)
        #节点内处理
        strIns=SectionToChinese(section)
        #检测当前section的的是否是0,如果是0的话,说明前面没有小节了,已处理完,添加空字符串的节权位就可以
        #否则说明还有小节,需要增加相应层级的节权位
        strIns=strIns+(chnUnitSetion[unitPos] if section != 0 else chnUnitSetion[0])
        #strIns += (section != 0) ? chnUnitSetion[unitPos] : chnUnitSetion[0]
        chnStr=strIns+chnStr
        #当满足小节内的值小于1000且值大于0的时候表示当前小节的千位是一个0,如果前面一小节还有值的时候则添0
        needZero = section < 1000 and section > 0
        num =num/10000
        unitPos=unitPos+1
        logging.debug( "Now:chnStr:"+chnStr)
    return chnStr
def SectionToChinese(section):
    #小节内转换,当前小节内的当前个数的独立计数的权位
    strIns=""
    chnStr=""
    unitPos = 0
    #先设置zero为true,为了规则二,两个相连的0只留一个
    zero = True
    while section > 0:
        v=section % 10
        if v==0:
            #当不是两个0相连的时候或者 添加0在数字中
            if not zero :
                #当出现一个0的时候就设置zero为true,当下一个还是0的时候就不添加0了
                zero = True
                chnStr=chnNumChar[v]+chnStr
        else:
            #当出现一个不是0的数字的时候就设置当前的zero标志为false表示下次遇到0的时候还是要添加
            zero = False
            strIns = chnNumChar[v]
            strIns += chnUnitChar[unitPos]
            #将这个strIns插入到总的字符串的开始的位置
            chnStr=strIns+chnStr
        #权位增加
        unitPos=unitPos+1
        #小节值除以10
        section /= 10  #python2
        #section=math.trunc(section/10)
    return chnStr
#主处理方法
def main(num):
    chnStr=""
    if num == 0 :
        chnStr="零"
    else:
        chnStr=NumberToChinese(num)
    logging.info( "result:"+chnStr)
if __name__ == '__main__':
    #设置环境编码
    reload(sys)
    sys.setdefaultencoding('utf8')
    #data = int(sys.argv[1])
    #初始化日志配置
    LOG_FORMAT = "%(asctime)s[%(levelname)s]%(message)s"
    DATE_FORMAT = '%Y-%m-%d %H:%M:%S' 
    logging.basicConfig(level=logging.DEBUG, format=LOG_FORMAT, datefmt=DATE_FORMAT)
    logging.info( "Beginning transfor. ")
    #修改这个数字,执行结果输出对应的中文数字
    main(230221032010)
    #main(data)
    logging.info( "transfor over. ")

相关推荐

戴尔官网保修查询入口(戴尔售后保质期查询)

可以按照以下步骤查询戴尔笔记本电脑的保修期:1.打开戴尔官网:https://www.戴尔.com/zh-cn/售后服务/保修政策.html2.点击页面上方的“服务与支持”按钮,进入戴尔的服务支持...

手机号邮箱登录入口(手机号邮箱官网)

手机163邮箱登录入口如下:163邮箱官网入口:https://smart.mail.163.com/login.htm点击进入登录或者注册邮箱即可。手机浏览器访问进入官网http://www.123...

sd卡(sd卡无法读取怎么修复)

  SD卡是大卡,相机用的;普通的手机内存卡,是小卡,正规的名称是macrosd卡,也就是微型SD卡。可以通过卡套转为普通的SD卡的大小。  其实就是大小不同。但手机上的内存卡,人们经常也俗称为SD...

路由器连接图(网络路由器连接图)
  • 路由器连接图(网络路由器连接图)
  • 路由器连接图(网络路由器连接图)
  • 路由器连接图(网络路由器连接图)
  • 路由器连接图(网络路由器连接图)
windows7蓝牙功能在哪里打开

点击搜索框在windows7系统主界面点击开始菜单,点击打开搜索框。输入命令输入services.msc后回车,在列表中找到并右击BluetoothSupportS...点击属性选择进入属性菜单,...

2010激活密钥(microsoft2010激活密钥)
2010激活密钥(microsoft2010激活密钥)

步骤/方式1officeprofessionalplus2010:(office专业版)6QFdx-pYH2G-ppYFd-C7RJM-BBKQ8Bdd3G-xM7FB-Bd2HM-YK63V-VQFdKVYBBJ-TRJpB-QFQ...

2025-11-19 04:03 off999

联想官方刷新bios工具(联想电脑刷新bios)

刷新BIOS需要使用联想的官方网站或授权维修中心来进行操作。以下是一些基本步骤:1.访问联想的官方网站,找到BIOS更新程序并下载。在下载过程中,请确保选择与您计算机型号匹配的版本。2.将下载的B...

苹果ios14系统下载(苹果ios14.1下载)
苹果ios14系统下载(苹果ios14.1下载)

1方法一步骤/方式一打开Appstore。步骤/方式二在搜索栏点击搜索框。步骤/方式三搜索并点击需要下载的软件。步骤/方式四点击获取。步骤/方式五最后验证ID密码即可。1.在应用商店搜索你要下载的应用名称。2.点击下载按钮,如果要求登...

2025-11-19 03:03 off999

office2010怎么免费永久激活密钥

用这个试试,一个KMS激活工具可以激活2010到2019的Office自家的目前用的就是这个microsoft6477.moe/1716.html直接使用这个Microsoftoffice2010...

类似爱加速的国内ip(类似爱加速的app)
类似爱加速的国内ip(类似爱加速的app)

推荐“V8盒子”。这一款免费无广告的模拟器,不同于其它软件盒子,而是类似于X8沙箱,满足游戏多开,画中画,悬浮球操作,熄屏后台运行等多功能的沙箱盒子.支持一键root,一键安装xposed框架,能在安卓/苹果手机上运行多个安卓/ios虚拟系...

2025-11-19 02:03 off999

阿里旺旺手机客户端(阿里旺旺手机app)

手机淘宝的旺旺在打开商品后,会看到左下角有个旺旺的图标,点击就可以联系了。  阿里旺旺是将原先的淘宝旺旺与阿里巴巴贸易通整合在一起的一个新品牌。它是淘宝和阿里巴巴为商人量身定做的免费网上商务沟通软件,...

最纯净的pe装机工具(pe工具哪个纯净)

U盘装系统步骤:1.制作U盘启动盘。这里推荐大白菜U盘启动盘制作工具,在网上一搜便是。2.U盘启动盘做好了,我们还需要一个GHOST文件,可以从网上下载一个ghost版的XP/WIN7/WIN8系统,...

装一个erp系统多少钱(wms仓库管理软件)

现在主流有客户端ERP和云端ERP两种客户端通常一次买断,价格在万元左右,但是还有隐性费用,你需要支付服务器、数据管理员,此外如果系统需要更新维护,你还需要支付另外一笔不菲的费用。云端ERP:优势...

cad2014序列号和密钥永久(autocad2014序列号和密钥)

1在cad2014中修改标注样式后,需要将其保存2单击“样式管理器”按钮,在弹出的窗口中选择修改后的标注样式,然后单击“设置为当前”按钮,再单击“保存当前样式”按钮,将其保存为新的样式名称3为了...

qq修改密保手机号(qq修改密保手机号是什么意思)

QQ更改绑定的手机号码操作步骤如下:1、打开手机主界面,找到“QQ”软件点击打开。2、输入正确的QQ账户和密码登录到qq主界面。3、点击左上角的头像“图片”,进入到个人中心界面。4、进入到个人中心界面...

取消回复欢迎 发表评论: