如何把2274587.84如何快速的转换为大写:贰佰贰拾柒万肆仟伍佰捌拾柒元捌角肆分?(下篇)

大家好,我是皮皮。

一、前言

前几天在Python黄金群【莫生气】问了一个Python数据处理的问题,需求如下:

大佬们,请教一个问题,2274587.84如何快速的转换为大写:贰佰贰拾柒万肆仟伍佰捌拾柒元捌角肆分?有没有工具或者网页啥的?不一定要Python实现。

使用百度上查到的代码,似乎不太好用,

def num2chinese(num):
    chinese_num = ["零", "壹", "贰", "参", "肆", "伍", "陆", "柒", "捌", "玖"]
    chinese_unit = ["", "拾", "佰", "仟", "万", "亿"]
    num_str = str(num)
    num_len = len(num_str)
    chinese_str = ''
    zero_flag = False
    for i in range(num_len):
        j = int(num_str[i])
        if i == 8:
            zero_flag = True
        else:
            if zero_flag:
                chinese_str += chinese_num[0]
                zero_flag = False
            chinese_str += chinese_num[j] + chinese_unit[num_len - i - 1]

    if zero_flag:
        chinese_str += chinese_num[0]
    return chinese_str


if __name__ == '__main__':
    print(num2chinese(135496))

代码运行之后出错,和实际预期的结果还是有差距的。

image.png

而且一旦假如小数,比方说有角分这样的,直接报错了。

image.png

二、实现过程

后来在讯飞星火上问到了一个答案,代码如下所示:

def num_to_chinese(num):

    chinese_num = {

        0: "零",

        1: "一",

        2: "二",

        3: "三",

        4: "四",

        5: "五",

        6: "六",

        7: "七",

        8: "八",

        9: "九"

    }

    chinese_unit = ["", "十", "百", "千", "万", "亿"]

    chinese_str = ""

    unit_index = 0

    for i in str(num):

        if i.isdigit():

            chinese_str += chinese_num[int(i)] + chinese_unit[unit_index]

            unit_index += 1

        else:

            chinese_str += i

    return chinese_str.strip("零") or "零"



num = 2274587.84

result = num_to_chinese(num)

print(result)

代码花里胡哨的,但是解决不了问题,一跑就出现数组越界的错误,尝试调教,说他错了,他仍然给你旧代码,甚至还给你一个不沾边的代码,整无语了。

后来问了Zelinna,给的代码看上去像那么回事,代码如下:

def num_to_chinese(num):

    chinese_num = {

        0: "零",

        1: "一",

        2: "二",

        3: "三",

        4: "四",

        5: "五",

        6: "六",

        7: "七",

        8: "八",

        9: "九"

    }

    chinese_unit = ["", "十", "百", "千", "万", "亿"]

    chinese_str = ""

    unit_index = 0

    for i in str(num):

        if i.isdigit():

            chinese_str += chinese_num[int(i)] + chinese_unit[unit_index]

            unit_index += 1

        else:

            chinese_str += i

    return chinese_str.strip("零") or "零"



num = 2274587.84

result = num_to_chinese(num)

print(result)

不过安装这个库之后,竟然报错,说里边对应的方法竟然不存在,这。。。很尴尬,还占用我内存,反手就uninstall掉了。

最后用了Excel设置单元格格式,好家伙,找到数据,然后右键-->设置单元格格式-->特殊-->人民币大写,就完事了,而且多行数据的话,直接一个填充就完事了,比问C老师,Z老师,K老师快得多!

image.png

顺利地解决了粉丝的问题。

后来【甯同学】,还给了一个方法。搜狗输入法,输入v+数字直接就是了。

image.png

三、总结

大家好,我是皮皮。这篇文章主要盘点了一个Python实战的问题,文中针对该问题,给出了具体的解析和代码实现,帮助粉丝顺利解决了问题。

最后感谢粉丝【莫生气】提问,感谢【巭孬嫑勥烎】给出的思路和代码解析,感谢【Ineverleft】、【瑜亮老师】等人参与学习交流。

【提问补充】温馨提示,大家在群里提问的时候。可以注意下面几点:如果涉及到大文件数据,可以数据脱敏后,发点demo数据来(小文件的意思),然后贴点代码(可以复制的那种),记得发报错截图(截全)。代码不多的话,直接发代码文字即可,代码超过50行这样的话,发个.py文件就行。

[图片上传失败...(image-2fdcfe-1689563010854)]

posted @ 2023-07-17 11:06  dcpeng  阅读(12)  评论(0编辑  收藏  举报