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


相关文章
|
8天前
|
Python
Python办公自动化:删除任意页数pdf页面
Python办公自动化:删除任意页数pdf页面
21 1
Python办公自动化:删除任意页数pdf页面
|
8天前
|
Python
Python办公自动化:xlwings对Excel进行分类汇总
Python办公自动化:xlwings对Excel进行分类汇总
25 1
|
8天前
|
Python
Python自动化:xlwings合并Excel
Python自动化:xlwings合并Excel
21 0
|
6天前
|
机器学习/深度学习 人工智能 运维
自动化运维的魔法:如何利用Python脚本提升工作效率
【9月更文挑战第29天】在数字时代的浪潮中,IT运维人员面临着前所未有的挑战和机遇。本文将通过深入浅出的方式,介绍自动化运维的基本概念、核心价值以及使用Python脚本实现自动化任务的方法。我们将从实际案例出发,探讨如何利用Python简化日常的系统管理任务,提高运维效率,并展望自动化运维的未来趋势。无论你是初学者还是有经验的运维专家,这篇文章都将为你开启一扇通往高效工作方式的大门。
10 2
|
9天前
|
存储 BI 数据库
使用 Python 实现自动化办公
使用 Python 实现自动化办公
16 4
|
8天前
|
数据安全/隐私保护 Python
Python办公自动化:给pdf加水印
Python办公自动化:给pdf加水印
10 0
|
8天前
|
Python
Python办公自动化:提取pdf文件中的图片
Python办公自动化:提取pdf文件中的图片
11 0
|
8天前
|
Python
Python办公自动化:xlwings对Excel进行列拆分
Python办公自动化:xlwings对Excel进行列拆分
19 0
|
8天前
|
Python
Python办公自动化:xlwings拆分Excel
Python办公自动化:xlwings拆分Excel
16 0
|
8天前
|
Python
Python自动化:xlwings替换Excel中内容
Python自动化:xlwings替换Excel中内容
20 0
下一篇
无影云桌面