python实现报表自动化1

简介: python实现报表自动化1

python 实现报表自动化1


  1. 报表介绍
    现有3张表,一张为交付表,一张为22年销售表,还有一张21年的销售表;
    交付表表头如下:

7962e6750ee24c16b288c6310acbc51c.png

21年、22年销售表头如下:

21372608847a4892abc37eecf6988df2.png

报表目的,将22年和21年的购进金额添加到F、G列,并且将22年新增的终端名称累加到新增的交付表下面。

  1. 自动化代码如下:
import pandas as pd
#忽略warning警告
import warnings
warnings.filterwarnings('ignore')
################################################## 修改文件名
#导入文件
df_22 = pd.read_excel('22年终端销售分析.xlsx')
df_21 = pd.read_excel('21年终端销售分析.xlsx')
df_jf = pd.read_excel('DDI直连清单-20220826.xlsx')
# 参数赋值
last_year = '21年8月购进'    ##############
this_year = '22年8月购进'    ##############
file_ddi = 'DDI直连清单-20220902.xlsx'      ##############################修改文件名
#屏蔽报错——SettingWithCopyWarning
pd.set_option('mode.chained_assignment', None)
#对齐参数
pd.set_option('display.unicode.ambiguous_as_wide', True)
pd.set_option('display.unicode.east_asian_width', True)
#处理交付表
#删除交付表21年与22年金额列
df_jf1 = df_jf.drop(labels=[last_year,this_year],axis = 1)  #删除交付表最后2列,方便后续合并,删除后不改变原表df_jx
#处理22年销售表
#为了找出新增终端,只保留:终端名称、省市区、终端类型几列, 并把删除后表头中”客户省、客户市、客户区“替换为”省、市、区“
df_22_1 = df_22[["终端名称","客户省","客户市","客户区","终端类型"]]
#删除df_22_1索引为0的行
df_22_1.drop(df_22_1.index[0], inplace=True)
#修改列名
df_22_1.rename(columns={'客户省':'省','客户市':'市','客户区':'区'}, inplace = True)
#将22年新增终端增到交付表中
#交付表与22表交集部分
df_jj = pd.merge(df_22_1, df_jf1, on=['终端名称'])
# df_jj.to_excel('df_jj.xlsx')
#差集——用22销售表减去22年与交付表的交集,得到22年7月新增部分终端
df_xinzeng = pd.concat([df_22_1,df_jj]).drop_duplicates(subset=['终端名称'],keep=False)
#删除交集与差集合并后的多余列
df_xinzeng = df_xinzeng.drop(labels=['省_x','市_x', '区_x', '终端类型_x','省_y' ,'市_y', '区_y', '终端类型_y'],axis = 1)
# df_xinzeng.to_excel('df_xinzeng.xlsx')
#将新增的终端放到交付表中
df_jf_res = pd.merge(df_jf1, df_xinzeng, on=['终端名称','省','市','区','终端类型'], how='outer')
# df_jf_res.to_excel('2.xlsx')
#将21年金额放到交付表
#删除21年索引为0的行
df_21.drop(df_21.index[0], inplace=True)
#筛选df_jf_res需要的两列
df_21=df_21[["终端名称","合计.1"]]
# 合并df_jf_res与df_21中的金额
df_jf_res = pd.merge(df_jf_res,df_21,how="left",on="终端名称")
#将合并表的21年金额更名
df_jf_res.rename(columns={'合计.1':last_year}, inplace = True)
#将21年金额列数值中”,“替换掉
df_jf_res[last_year] = df_jf_res[last_year].str.replace(',','')
df_jf_res[last_year] = pd.to_numeric(df_jf_res[last_year],errors='raise')
# 将交付表中21年金额为空的填充为0
df_jf_res.fillna(0,inplace=True)
#将22年金额放到交付表
#删除22年索引为0的行
df_22.drop(df_22.index[0], inplace=True)
#筛选df_jf_res需要的两列
df_22=df_22[["终端名称","合计.1"]]
# 合并df_jf_res与df_22中的金额
df_jf_res = pd.merge(df_jf_res,df_22,how="left",on="终端名称")
#将合并表的22年金额更名
df_jf_res.rename(columns={'合计.1':this_year}, inplace = True)
#将22年金额列数值中”,“替换掉
df_jf_res[this_year] = df_jf_res[this_year].str.replace(',','')
df_jf_res[this_year] = pd.to_numeric(df_jf_res[this_year],errors='raise')
# 将22年金额为空的填充为0
df_jf_res.fillna(0,inplace=True)
#输出文件
df_jf_res.to_excel(file_ddi,index=False)
#修改列宽
file_path = './DDI直连清单-20220902.xlsx'      ####################修改文件名
sheet_name = 'Sheet1'
with pd.ExcelWriter(file_path, engine='xlsxwriter') as writer:
    # 数据传给Excel的writer
    df_jf_res.to_excel(writer, index=False, sheet_name=sheet_name)
    # 再从writer加载回该sheet
    worksheet = writer.sheets[sheet_name]
    # 循环每一列的列序号,设置列宽为20个单位(指Excel中的列宽单位)
    # for idx in range(df_jf_res.shape[1]):
    #     print(df_jf_res.shape[1])
    worksheet.set_column(0,0, 60)
    worksheet.set_column(5,6, 15)    # .set_column(a,b,c)函数三个参数,a代表起始列,b代表终止列,c为列宽
    # worksheet.set_column(6, 6, 15)
    writer.save()   # 保存文件


相关文章
|
16天前
|
Java 测试技术 持续交付
【入门思路】基于Python+Unittest+Appium+Excel+BeautifulReport的App/移动端UI自动化测试框架搭建思路
本文重点讲解如何搭建App自动化测试框架的思路,而非完整源码。主要内容包括实现目的、框架设计、环境依赖和框架的主要组成部分。适用于初学者,旨在帮助其快速掌握App自动化测试的基本技能。文中详细介绍了从需求分析到技术栈选择,再到具体模块的封装与实现,包括登录、截图、日志、测试报告和邮件服务等。同时提供了运行效果的展示,便于理解和实践。
58 4
【入门思路】基于Python+Unittest+Appium+Excel+BeautifulReport的App/移动端UI自动化测试框架搭建思路
|
6天前
|
开发者 Python
使用Python实现自动化邮件通知:当长时程序运行结束时
本文介绍了如何使用Python实现自动化邮件通知功能,当长时间运行的程序完成后自动发送邮件通知。主要内容包括:项目背景、设置SMTP服务、编写邮件发送函数、连接SMTP服务器、发送邮件及异常处理等步骤。通过这些步骤,可以有效提高工作效率,避免长时间等待程序结果。
43 9
|
6天前
|
运维 监控 网络安全
自动化运维的崛起:如何利用Python脚本简化日常任务
【10月更文挑战第43天】在数字化时代的浪潮中,运维工作已从繁琐的手工操作转变为高效的自动化流程。本文将引导您了解如何运用Python编写脚本,以实现日常运维任务的自动化,从而提升工作效率和准确性。我们将通过一个实际案例,展示如何使用Python来自动部署应用、监控服务器状态并生成报告。文章不仅适合运维新手入门,也能为有经验的运维工程师提供新的视角和灵感。
|
11天前
|
存储 Python
Python自动化脚本编写指南
【10月更文挑战第38天】本文旨在为初学者提供一条清晰的路径,通过Python实现日常任务的自动化。我们将从基础语法讲起,逐步引导读者理解如何将代码块组合成有效脚本,并探讨常见错误及调试技巧。文章不仅涉及理论知识,还包括实际案例分析,帮助读者快速入门并提升编程能力。
38 2
|
13天前
|
运维 监控 Python
自动化运维:使用Python脚本简化日常任务
【10月更文挑战第36天】在数字化时代,运维工作的效率和准确性成为企业竞争力的关键。本文将介绍如何通过编写Python脚本来自动化日常的运维任务,不仅提高工作效率,还能降低人为错误的风险。从基础的文件操作到进阶的网络管理,我们将一步步展示Python在自动化运维中的应用,并分享实用的代码示例,帮助读者快速掌握自动化运维的核心技能。
28 3
|
12天前
|
数据采集 IDE 测试技术
Python实现自动化办公:从基础到实践###
【10月更文挑战第21天】 本文将探讨如何利用Python编程语言实现自动化办公,从基础概念到实际操作,涵盖常用库、脚本编写技巧及实战案例。通过本文,读者将掌握使用Python提升工作效率的方法,减少重复性劳动,提高工作质量。 ###
28 1
|
19天前
|
运维 监控 应用服务中间件
自动化运维:如何利用Python脚本提升工作效率
【10月更文挑战第30天】在快节奏的IT行业中,自动化运维已成为提升工作效率和减少人为错误的关键技术。本文将介绍如何使用Python编写简单的自动化脚本,以实现日常运维任务的自动化。通过实际案例,我们将展示如何用Python脚本简化服务器管理、批量配置更新以及监控系统性能等任务。文章不仅提供代码示例,还将深入探讨自动化运维背后的理念,帮助读者理解并应用这一技术来优化他们的工作流程。
|
19天前
|
数据采集 Web App开发 JavaScript
爬虫策略规避:Python爬虫的浏览器自动化
爬虫策略规避:Python爬虫的浏览器自动化
|
17天前
|
Web App开发 测试技术 数据安全/隐私保护
自动化测试的魔法:使用Python进行Web应用测试
【10月更文挑战第32天】本文将带你走进自动化测试的世界,通过Python和Selenium库的力量,展示如何轻松对Web应用进行自动化测试。我们将一起探索编写简单而强大的测试脚本的秘诀,并理解如何利用这些脚本来确保我们的软件质量。无论你是测试新手还是希望提升自动化测试技能的开发者,这篇文章都将为你打开一扇门,让你看到自动化测试不仅可行,而且充满乐趣。
|
4天前
|
存储 数据挖掘 开发者
Python编程入门:从零到英雄
在这篇文章中,我们将一起踏上Python编程的奇幻之旅。无论你是编程新手,还是希望拓展技能的开发者,本教程都将为你提供一条清晰的道路,引导你从基础语法走向实际应用。通过精心设计的代码示例和练习,你将学会如何用Python解决实际问题,并准备好迎接更复杂的编程挑战。让我们一起探索这个强大的语言,开启你的编程生涯吧!
下一篇
无影云桌面