您当前的位置:首页 > 电脑百科 > 程序开发 > 语言 > Python

python 一键生成对账单

时间:2022-06-29 09:05:46  来源:  作者:Goodgoodstudy

工作中经常会用到对账单,一般我们都是用Excel进行汇总,每次总是有大量的重复工作,很是烦人,今天我教大家用Python/ target=_blank class=infotextkey>Python一键生成对账单,非常省事,再也不用加班加点了。

python 一键生成对账单

 

一、准备基础数据

首先,我们用Excel创建三张基础数据表,其中sheet1重新命名为客户销售明细表,sheet2预收款明细表,sheet3期初余额表。如图:(我这里的三张表,都放在了我的电脑桌面上,一个叫账户平衡表.xlsx的Excel工作簿中,你也可以建三个工作簿分别存放,图2、图3、图4中可看到我的基础数据表,里面有三个sheet表,并已重命名,且每一张表都预输入了客户相关信息。)

 

python 一键生成对账单

图1


python 一键生成对账单

图2


python 一键生成对账单

图3


python 一键生成对账单

图4

二、要求

输入客户名称,一键调出客户销售明细及账户余额等信息。

三、思路

由于数据分别存放在三张表上,所以我们最关键的步骤就是要合并三张表,然后写搜索条件代码即可。

四、写代码

1、导入pandas模块

import pandas as pd

 

python 一键生成对账单

 

2、导入数据并处理空值

df1=pd.read_excel(r"C:UsersAdministratorDesktop账户平衡表.xlsx",sheet_name='客户销售明细')

df2=pd.read_excel(r"C:UsersAdministratorDesktop账户平衡表.xlsx",sheet_name='预收款')

df3=pd.read_excel(r"C:UsersAdministratorDesktop账户平衡表.xlsx",sheet_name='期初余额')

df1.fillna(0,inplace=True)

df2.fillna(0,inplace=True)

df3.fillna(0,inplace=True)

3、设置要查询的变量

name='客户名称'

4、设置要查询的字段

list1=['customer','product','单位','单价','发货','调货','退货','实销','运费']

list2=['customer','本期预收_玉米','本期预收_小麦']

list3=['customer','期初余额_玉米','期初余额_小麦']

df1=df1[list1]

df2=df2[list2]

df3=df3[list3]

5、分别对三个表进行分类汇总

表1

df1=df1.groupby(['customer','product','单价']).sum()

df1.reset_index('product',inplace=True,drop=False)

df1.reset_index(inplace=True)

df1=df1[df1['customer']==name]

df1.reset_index(inplace=True)

df1

del df1['index']

df1

效果如下图:

 

python 一键生成对账单

 

表2

df2.groupby(['customer']).sum()

df2=df2[df2['customer']==name]

df2.reset_index(inplace=True,drop=False)

df2

del df2['index']

del df2['customer']

df2

 

 

python 一键生成对账单

 

表3

df3.groupby(['customer']).sum()

df3=df3[df3['customer']==name]

df3.reset_index(inplace=True,drop=False)

df3

del df3['index']

del df3['customer']

5、三表合并

df2=df1.merge(df2,left_index=True,right_index=True,how='left')

df3=df2.merge(df3,left_index=True,right_index=True,how='left')

df3

df3.fillna(0,inplace=True)

df3

效果如下:

python 一键生成对账单

 

6、对合并后的总表进行相关计算

df3['销售额']=df3['实销']*df3['单价']

df3['应收账款_玉米']=df3['销售额']-df3['运费']-df3['本期预收_玉米']+df3['期初余额_玉米']

df3['应收账款_小麦']=df3['期初余额_小麦']-df3['本期预收_小麦']

df3['应收账款']=df3['应收账款_玉米']+df3['应收账款_小麦']

df3.fillna(0,inplace=True)

df3

效果如下:

python 一键生成对账单

 

7、整理结果

order=['customer','product','发货','调货','退货','实销','单价','销售额','运费','期初余额_玉米','本期预收_玉米','应收账款_玉米','期初余额_小麦','本期预收_小麦','应收账款_小麦','应收账款']

df4=df3[order]

df4=pd.pivot_table(df4,index=['customer','product','单价'],aggfunc=sum,margins=True)

df4.reset_index(inplace=True)

df4=df4[order]

df4

对账单结果:

python 一键生成对账单

 

关键步骤总结:

1、分别导入三个基础表

2、分别汇总三个表,并按条件进行筛选

3、将三个符合条件的表合并

4、整理输出结果

 

今天的文章至此结束,如有不妥,请在下方留言评论。欢迎点赞、收藏、关注和评论。



Tags:python   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,不构成投资建议。投资者据此操作,风险自担。如有任何标注错误或版权侵犯请与我们联系,我们将及时更正、删除。
▌相关推荐
一篇文章教会你使用Python中三种简单的函数
所谓函数,就是指:把某些特定功能的代码组成为一个整体,这个整体就叫做函数。一、函数简介所谓函数,就是指:把某些特定功能的代码组成为一个整体,这个整体就叫做函数。二、函数定义...【详细内容】
2024-04-11  Search: python  点击:(12)  评论:(0)  加入收藏
一篇文章带你了解Python的分布式进程接口
在Thread和Process中,应当优选Process,因为Process更稳定,而且,Process可以分布到多台机器上,而Thread最多只能分布到同一台机器的多个CPU上。一、前言在Thread和Process中,应当优...【详细内容】
2024-04-11  Search: python  点击:(9)  评论:(0)  加入收藏
Python 可视化:Plotly 库使用基础
当使用 Plotly 进行数据可视化时,我们可以通过以下示例展示多种绘图方法,每个示例都会有详细的注释和说明。1.创建折线图import plotly.graph_objects as go# 示例1: 创建简单...【详细内容】
2024-04-01  Search: python  点击:(15)  评论:(0)  加入收藏
Python 办公神器:教你使用 Python 批量制作 PPT
介绍本文将介绍如何使用openpyxl和pptx库来批量制作PPT奖状。本文假设你已经安装了python和这两个库。本文的场景是:一名基层人员,要给一次比赛活动获奖的500名选手制作奖状,并...【详细内容】
2024-03-26  Search: python  点击:(21)  评论:(0)  加入收藏
Python实现工厂模式、抽象工厂,单例模式
工厂模式是一种常见的设计模式,它可以帮助我们创建对象的过程更加灵活和可扩展。在Python中,我们可以使用函数和类来实现工厂模式。一、Python中实现工厂模式工厂模式是一种常...【详细内容】
2024-03-07  Search: python  点击:(36)  评论:(0)  加入收藏
不可不学的Python技巧:字典推导式使用全攻略
Python的字典推导式是一种优雅而强大的工具,用于创建字典(dict)。这种方法不仅代码更加简洁,而且执行效率高。无论你是Python新手还是有经验的开发者,掌握字典推导式都将是你技能...【详细内容】
2024-02-22  Search: python  点击:(41)  评论:(0)  加入收藏
如何进行Python代码的代码重构和优化?
Python是一种高级编程语言,它具有简洁、易于理解和易于维护的特点。然而,代码重构和优化对于保持代码质量和性能至关重要。什么是代码重构?代码重构是指在不改变代码外部行为的...【详细内容】
2024-02-22  Search: python  点击:(42)  评论:(0)  加入收藏
Python开发者必备的八个PyCharm插件
在编写代码的过程中,括号几乎无处不在,以至于有时我们会拼命辨别哪个闭合括号与哪个开头的括号相匹配。这款插件能帮助解决这个众所周知的问题。前言在PyCharm中浏览插件列表...【详细内容】
2024-01-26  Search: python  点击:(92)  评论:(0)  加入收藏
Python的Graphlib库,再也不用手敲图结构了
Python中的graphlib库是一个功能强大且易于使用的工具。graphlib提供了许多功能,可以帮助您创建、操作和分析图形对象。本文将介绍graphlib库的主要用法,并提供一些示例代码和...【详细内容】
2024-01-26  Search: python  点击:(93)  评论:(0)  加入收藏
大语言模型插件功能在携程的Python实践
作者简介成学,携程高级安全研发工程师,关注Python/Golang后端开发、大语言模型等领域。一、背景2023年初,科技圈最火爆的话题莫过于大语言模型了,它是一种全新的聊天机器人模型,...【详细内容】
2024-01-26  Search: python  点击:(84)  评论:(0)  加入收藏
▌简易百科推荐
一篇文章教会你使用Python中三种简单的函数
所谓函数,就是指:把某些特定功能的代码组成为一个整体,这个整体就叫做函数。一、函数简介所谓函数,就是指:把某些特定功能的代码组成为一个整体,这个整体就叫做函数。二、函数定义...【详细内容】
2024-04-11  Go语言进阶学习  微信公众号  Tags:Python   点击:(12)  评论:(0)  加入收藏
一篇文章带你了解Python的分布式进程接口
在Thread和Process中,应当优选Process,因为Process更稳定,而且,Process可以分布到多台机器上,而Thread最多只能分布到同一台机器的多个CPU上。一、前言在Thread和Process中,应当优...【详细内容】
2024-04-11  Go语言进阶学习    Tags:Python   点击:(9)  评论:(0)  加入收藏
Python 可视化:Plotly 库使用基础
当使用 Plotly 进行数据可视化时,我们可以通过以下示例展示多种绘图方法,每个示例都会有详细的注释和说明。1.创建折线图import plotly.graph_objects as go# 示例1: 创建简单...【详细内容】
2024-04-01  Python技术    Tags:Python   点击:(15)  评论:(0)  加入收藏
Python 办公神器:教你使用 Python 批量制作 PPT
介绍本文将介绍如何使用openpyxl和pptx库来批量制作PPT奖状。本文假设你已经安装了python和这两个库。本文的场景是:一名基层人员,要给一次比赛活动获奖的500名选手制作奖状,并...【详细内容】
2024-03-26  Python技术  微信公众号  Tags:Python   点击:(21)  评论:(0)  加入收藏
Python实现工厂模式、抽象工厂,单例模式
工厂模式是一种常见的设计模式,它可以帮助我们创建对象的过程更加灵活和可扩展。在Python中,我们可以使用函数和类来实现工厂模式。一、Python中实现工厂模式工厂模式是一种常...【详细内容】
2024-03-07  Python都知道  微信公众号  Tags:Python   点击:(36)  评论:(0)  加入收藏
不可不学的Python技巧:字典推导式使用全攻略
Python的字典推导式是一种优雅而强大的工具,用于创建字典(dict)。这种方法不仅代码更加简洁,而且执行效率高。无论你是Python新手还是有经验的开发者,掌握字典推导式都将是你技能...【详细内容】
2024-02-22  子午Python  微信公众号  Tags:Python技巧   点击:(41)  评论:(0)  加入收藏
如何进行Python代码的代码重构和优化?
Python是一种高级编程语言,它具有简洁、易于理解和易于维护的特点。然而,代码重构和优化对于保持代码质量和性能至关重要。什么是代码重构?代码重构是指在不改变代码外部行为的...【详细内容】
2024-02-22  编程技术汇    Tags:Python代码   点击:(42)  评论:(0)  加入收藏
Python开发者必备的八个PyCharm插件
在编写代码的过程中,括号几乎无处不在,以至于有时我们会拼命辨别哪个闭合括号与哪个开头的括号相匹配。这款插件能帮助解决这个众所周知的问题。前言在PyCharm中浏览插件列表...【详细内容】
2024-01-26  Python学研大本营  微信公众号  Tags:PyCharm插件   点击:(92)  评论:(0)  加入收藏
Python的Graphlib库,再也不用手敲图结构了
Python中的graphlib库是一个功能强大且易于使用的工具。graphlib提供了许多功能,可以帮助您创建、操作和分析图形对象。本文将介绍graphlib库的主要用法,并提供一些示例代码和...【详细内容】
2024-01-26  科学随想录  微信公众号  Tags:Graphlib库   点击:(93)  评论:(0)  加入收藏
Python分布式爬虫打造搜索引擎
简单分布式爬虫结构主从模式是指由一台主机作为控制节点负责所有运行网络爬虫的主机进行管理,爬虫只需要从控制节点那里接收任务,并把新生成任务提交给控制节点就可以了,在这个...【详细内容】
2024-01-25  大雷家吃饭    Tags:Python   点击:(62)  评论:(0)  加入收藏
站内最新
站内热门
站内头条