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()   # 保存文件


相关文章
|
29天前
|
搜索推荐 Python
使用Python自动化生成物业通知单
本文介绍如何使用Python结合Pandas和python-docx库自动化生成物业通知单。通过读取Excel数据并填充至Word模板,实现高效准确的通知单批量制作。包括环境准备、代码解析及效果展示,适用于物业管理场景。
62 14
|
1月前
|
数据采集 数据可视化 数据挖掘
利用Python自动化处理Excel数据:从基础到进阶####
本文旨在为读者提供一个全面的指南,通过Python编程语言实现Excel数据的自动化处理。无论你是初学者还是有经验的开发者,本文都将帮助你掌握Pandas和openpyxl这两个强大的库,从而提升数据处理的效率和准确性。我们将从环境设置开始,逐步深入到数据读取、清洗、分析和可视化等各个环节,最终实现一个实际的自动化项目案例。 ####
100 10
|
7天前
|
Python
自动化微信朋友圈:Python脚本实现自动发布动态
本文介绍如何使用Python脚本自动化发布微信朋友圈动态,节省手动输入的时间。主要依赖`pyautogui`、`time`、`pyperclip`等库,通过模拟鼠标和键盘操作实现自动发布。代码涵盖打开微信、定位朋友圈、准备输入框、模拟打字等功能。虽然该方法能提高效率,但需注意可能违反微信使用条款,存在风险。定期更新脚本以适应微信界面变化也很重要。
106 60
|
2月前
|
数据采集 监控 数据挖掘
Python自动化脚本:高效办公新助手###
本文将带你走进Python自动化脚本的奇妙世界,探索其在提升办公效率中的强大潜力。随着信息技术的飞速发展,重复性工作逐渐被自动化工具取代。Python作为一门简洁而强大的编程语言,凭借其丰富的库支持和易学易用的特点,成为编写自动化脚本的首选。无论是数据处理、文件管理还是网页爬虫,Python都能游刃有余地完成任务,极大地减轻了人工操作的负担。接下来,让我们一起领略Python自动化脚本的魅力,开启高效办公的新篇章。 ###
|
19天前
|
JSON 数据可视化 测试技术
python+requests接口自动化框架的实现
通过以上步骤,我们构建了一个基本的Python+Requests接口自动化测试框架。这个框架具有良好的扩展性,可以根据实际需求进行功能扩展和优化。它不仅能提高测试效率,还能保证接口的稳定性和可靠性,为软件质量提供有力保障。
50 7
|
1月前
|
Android开发 开发者 Python
通过标签清理微信好友:Python自动化脚本解析
微信已成为日常生活中的重要社交工具,但随着使用时间增长,好友列表可能变得臃肿。本文介绍了一个基于 Python 的自动化脚本,利用 `uiautomator2` 库,通过模拟用户操作实现根据标签批量清理微信好友的功能。脚本包括环境准备、类定义、方法实现等部分,详细解析了如何通过标签筛选并删除好友,适合需要批量管理微信好友的用户。
51 7
|
1月前
|
安全 API 文件存储
Yagmail邮件发送库:如何用Python实现自动化邮件营销?
本文详细介绍了如何使用Yagmail库实现自动化邮件营销。Yagmail是一个简洁强大的Python库,能简化邮件发送流程,支持文本、HTML邮件及附件发送,适用于数字营销场景。文章涵盖了Yagmail的基本使用、高级功能、案例分析及最佳实践,帮助读者轻松上手。
35 4
|
1月前
|
敏捷开发 测试技术 持续交付
自动化测试之美:从零开始搭建你的Python测试框架
在软件开发的马拉松赛道上,自动化测试是那个能让你保持节奏、避免跌宕起伏的神奇小助手。本文将带你走进自动化测试的世界,用Python这把钥匙,解锁高效、可靠的测试框架之门。你将学会如何步步为营,构建属于自己的测试庇护所,让代码质量成为晨跑时清新的空气,而不是雾霾中的忧虑。让我们一起摆脱手动测试的繁琐枷锁,拥抱自动化带来的自由吧!
|
2月前
|
监控 数据挖掘 数据安全/隐私保护
Python脚本:自动化下载视频的日志记录
Python脚本:自动化下载视频的日志记录