Python编程案例:中文金额转换并计算

简介: Python编程案例:中文金额转换并计算

Python编程案例:中文金额转换并计算
平时的工作、生活中经常遇到金额是中文大写的表达方式,那么就无法直接进行计算和统计。这样就需要将中文大写的金额转换为小写的阿拉伯数字,来计算总额,并将计算结果输出。实现这个功能需要用到rmbTrans模块。

运行环境:

OS:macOS Monterey Version 12.3.1

IDE:PyCharm 2020.1

首先需要安装rmbTrans模块,在命令行输入如下命令:

(venv) (base) liuxiaowei@MacBookAir  % pip install rmbTrans

备注:如果安装不成功可以添加如下参数(清华的国内镜像)

pip install openpyxl -i https://pypi.tuna.tsinghua.edu.cn/simple/

中文金额数据如下表:
image.png

对表中的总金额进行转换计算,源码如下:

#_*_coding:utf-8_*_
# 作者      :liuxiaowei
# 创建时间   :4/8/22 10:07 PM
# 文件      :中文金额计算.py
# IDE      :PyCharm

import os
import openpyxl
# 导入人民币转换模块
import rmbTrans

# 工作目录赋值给workPath
workPath = '/Users/liuxiaowei/amount_covert'
# 指定workPath为当前工作目录
os.chdir(workPath)

# 读取工作簿
wb = openpyxl.load_workbook(os.listdir()[0])

# 六月采购总金额
cg_Amount = 0
# 读取表中到数据
for rowData in wb['6月供货'].rows:
    # 读取第567列数据
    if rowData[4].value == '货物名称' or rowData[5].value == '总税额' or rowData[6].value == '总金额':
        continue
    price1 = rmbTrans.trans(rowData[4].value)
    price2 = rmbTrans.trans(rowData[5].value)
    price3 = rmbTrans.trans(rowData[6].value)
    cg_Amount += price3
    print(f'{rowData[3].value}的商品总价:{price1}元,总税额:{price2}元,总金额:{price3}元')
print(f'六月份采购总金额{cg_Amount}元')

运行结果如下:

开口哭牌芹菜味薯片的商品总价:3600元,总税额:612元,总金额:4212元
开口哭牌榴莲味薯片的商品总价:3600元,总税额:612.55元,总金额:4212.55元
开口哭牌猕猴桃味薯片的商品总价:3600元,总税额:612元,总金额:4212元
开口哭牌猕猴桃味口香糖的商品总价:3500元,总税额:595元,总金额:4095元
开口哭牌麻辣味口香糖的商品总价:3900元,总税额:663元,总金额:4563元
开口哭牌蟹黄味口香糖的商品总价:3500元,总税额:595.0699999999999元,总金额:4095.07元
开口哭牌没有一点味口香糖的商品总价:3500元,总税额:595元,总金额:4095元
开口哭牌榴莲味口香糖的商品总价:1000元,总税额:170元,总金额:1170元
开口哭牌没有一点味薯片的商品总价:1200元,总税额:204元,总金额:1404元
六月份采购总金额52065.62
相关文章
|
1月前
|
存储 数据采集 人工智能
Python编程入门:从零基础到实战应用
本文是一篇面向初学者的Python编程教程,旨在帮助读者从零开始学习Python编程语言。文章首先介绍了Python的基本概念和特点,然后通过一个简单的例子展示了如何编写Python代码。接下来,文章详细介绍了Python的数据类型、变量、运算符、控制结构、函数等基本语法知识。最后,文章通过一个实战项目——制作一个简单的计算器程序,帮助读者巩固所学知识并提高编程技能。
|
22天前
|
Unix Linux 程序员
[oeasy]python053_学编程为什么从hello_world_开始
视频介绍了“Hello World”程序的由来及其在编程中的重要性。从贝尔实验室诞生的Unix系统和C语言说起,讲述了“Hello World”作为经典示例的起源和流传过程。文章还探讨了C语言对其他编程语言的影响,以及它在系统编程中的地位。最后总结了“Hello World”、print、小括号和双引号等编程概念的来源。
106 80
|
11天前
|
Python
[oeasy]python055_python编程_容易出现的问题_函数名的重新赋值_print_int
本文介绍了Python编程中容易出现的问题,特别是函数名、类名和模块名的重新赋值。通过具体示例展示了将内建函数(如`print`、`int`、`max`)或模块名(如`os`)重新赋值为其他类型后,会导致原有功能失效。例如,将`print`赋值为整数后,无法再用其输出内容;将`int`赋值为整数后,无法再进行类型转换。重新赋值后,这些名称失去了原有的功能,可能导致程序错误。总结指出,已有的函数名、类名和模块名不适合覆盖赋新值,否则会失去原有功能。如果需要使用类似的变量名,建议采用其他命名方式以避免冲突。
33 14
|
21天前
|
分布式计算 大数据 数据处理
技术评测:MaxCompute MaxFrame——阿里云自研分布式计算框架的Python编程接口
随着大数据和人工智能技术的发展,数据处理的需求日益增长。阿里云推出的MaxCompute MaxFrame(简称“MaxFrame”)是一个专为Python开发者设计的分布式计算框架,它不仅支持Python编程接口,还能直接利用MaxCompute的云原生大数据计算资源和服务。本文将通过一系列最佳实践测评,探讨MaxFrame在分布式Pandas处理以及大语言模型数据处理场景中的表现,并分析其在实际工作中的应用潜力。
57 2
|
1月前
|
Python
Python中的函数是**一种命名的代码块,用于执行特定任务或计算
Python中的函数是**一种命名的代码块,用于执行特定任务或计算
50 18
|
1月前
|
小程序 开发者 Python
探索Python编程:从基础到实战
本文将引导你走进Python编程的世界,从基础语法开始,逐步深入到实战项目。我们将一起探讨如何在编程中发挥创意,解决问题,并分享一些实用的技巧和心得。无论你是编程新手还是有一定经验的开发者,这篇文章都将为你提供有价值的参考。让我们一起开启Python编程的探索之旅吧!
49 10
|
1月前
|
人工智能 数据挖掘 开发者
探索Python编程之美:从基础到进阶
本文是一篇深入浅出的Python编程指南,旨在帮助初学者理解Python编程的核心概念,并引导他们逐步掌握更高级的技术。文章不仅涵盖了Python的基础语法,还深入探讨了面向对象编程、函数式编程等高级主题。通过丰富的代码示例和实践项目,读者将能够巩固所学知识,提升编程技能。无论你是编程新手还是有一定经验的开发者,这篇文章都将为你提供有价值的参考和启示。让我们一起踏上Python编程的美妙旅程吧!
|
8月前
|
算法 Python Java
Python每日一练(20230426) 删除重复字符、颜色分类、计算圆周率
Python每日一练(20230426) 删除重复字符、颜色分类、计算圆周率
86 0
Python每日一练(20230426) 删除重复字符、颜色分类、计算圆周率
|
Python
Python计算圆周率
Python计算圆周率
122 0
|
Python
用python采用蒙特卡洛模拟计算圆周率--学习笔记15
用python采用蒙特卡洛模拟计算圆周率--学习笔记15
151 0