python 一键生成对账单

python 一键生成对账单

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

一、准备基础数据

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

图1

图2

图3

图4

二、要求

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

三、思路

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

四、写代码

1、导入pandas模块

import pandas as pd

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

效果如下图:

表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

表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

效果如下:

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

df3[‘销售额’]=df3[‘实销’]*df3[‘单价’]

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

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

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

df3.fillna(0,inplace=True)

df3

效果如下:

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

对账单结果:

关键步骤总结:

1、分别导入三个基础表

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

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

4、整理输出结果

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

郑重声明:本文内容及图片均整理自互联网,不代表本站立场,版权归原作者所有,如有侵权请联系管理员(admin#wlmqw.com)删除。
(0)
用户投稿
上一篇 2022年7月2日
下一篇 2022年7月2日

相关推荐

  • “男子46万元被冻结”?支付宝回应了

    余额宝里46万块钱无法取出?日前,哈尔滨市民于先生反映的问题引发广泛关注。 6月22日,支付宝安全中心回应表示,根据举报信息和平台风险系统识别,于先生的账户交易行为存在异常情形,可…

    2022年6月24日
  • 能不能借大额网贷买房 答案很明显

    贷款买房是常见的情况,购房者前期只要准备首付款即可,后期按合同规定月供,这样可以保持足够资金流,但首付也不是小数目,那么能不能借大额网贷买房吗?下面来看分析。 不能够借大额网贷来买…

    2022年9月5日
  • 微信群没有减号怎么踢人(微信群聊怎么踢人)

    我们在创建群之后,最头疼的问题就是有人在群里发垃圾营销广告链接了。但是我们有时候经常会因为手头上刚好有事情在做不能及时踢掉这些人而导致社群人员流失。 现在企业微信有了防骚扰功能,我…

    2022年11月18日
  • 工信部出手,一键解除手机绑定账号

    不知道大伙平时有没这个感受,用个啥 App 都得登录,不登录的话啥子功能都莫得。 你退一步用微信登录吧,它还不情愿,非得让你用手机号绑定,虽然实名制的手机号更利于管理,但对于用户来…

    2022年6月12日
  • 润建股份:以通信管维为基,能源和信息管维构筑公司成长新引擎

    (报告出品方/分析师:光大证券 石崎良 朱宇澍) 1、润建股份:“万物互联”时代领先的“智能物业” 1.1、公司布局通信、信息和能源三大领域管维服务 润建股份定位为通信信息网络和能…

    2022年8月13日
  • @以案普法 _以案普法_2022年09月16日_微头条

    广东湛江,一男子因被银行扣了3块钱的小额账户管理费,遂将银行告上法院,要求赔偿自己1元钱,并退回已扣款项。(来源:广东省湛江市中级人民法院)小许在银行办了一张银行卡,并办理了开户业…

    2022年9月17日
  • 银行房贷流水不够很重要吗 要求多少?

    在如今,申请房贷的时候,最基本的条件是个人的收入为月供的两倍以上,很多人对此的认识不多,那么银行房贷流水不够很重要吗?下文就来带大家了解一下。 银行房贷流水不够是很重要的,客户若去…

    2022年8月27日
  • 三大晶圆厂决战2纳米

    来源:内容来自镜报,谢谢。 尽管总体经济利空不断,但面对智慧型手机等消费性电子产品需求萎缩,全球晶圆代工龙头台积电今年5月营收,依旧缴出亮丽的成绩单,以新台币1,857亿500万元…

    2022年6月15日
  • 倒春寒小麦怎么防冻 小麦倒春寒的预防措施

    倒春寒对农作物的影响可大了,主要影响的是早稻,早麦和蔬菜等,所以种植这些农作物的农民们,在倒春寒到来之前要做好预防措施呀,若是预防不得当也要及时补救,让自己的农作物得以成长起来,以…

    2022年7月30日
  • 中国品牌口碑指数2022Q2空调口碑榜情人节再甜也离不开空调的怀抱

    2022年8月4日,中国品牌口碑指数:2022年二季度空调品牌口碑报告(以下简称《报告》)在京发布。 本期研究报告从首页大数据口碑监测平台的空调品牌中,筛选了20个品牌作为研究对象…

    2022年8月5日

联系我们

联系邮箱:admin#wlmqw.com
工作时间:周一至周五,10:30-18:30,节假日休息