一、需求描述
两个文件夹分别存放本期数和上期数,对每个文件夹中的每个单元格对应求和汇总得出最终的结果,并写入到表格形式一样的Excel中的对应位置。
表格样式:
本期数占用区域是7-28行,上期数单元格和本期数单元格样式相同,只不过在本sheet页面的下半部分,51-72行
第一张sheet页与结果表样式:
第二张sheet页面与结果表样式:
二、代码实现
import os
import time
import pandas as pd
import xlrd #导入模块
from xlutils.copy import copy
# 解决dataframe显示不全的问题
pd.set_option('display.max_columns', 100) # 显示全部列
pd.set_option('display.max_row', 500) # 显示全部行
pd.set_option('display.width', 1000) # 解决自动换行的问题
#读取本期数进行汇总并写入到新的表格中
def write(this_path,excel_path,row,column):
datalist = []
dic = {
}
for excel in os.listdir(this_path):
path=os.path.join(this_path,excel)
print(path)
#读取本期数的数据区域
data = pd.read_excel(path,sheet_name='月报表-融资支持情况',header=7,nrows=20,usecols='A:K',index_col=0)
data = data.iloc[2:]
#重新设置表头
data.columns=(['余额','授信户数','新增授信户数','新增首次授信户数','有贷款余额户数','新发放贷款户数','新发放首次贷款户数','信用贷款余额','涉及贷款金额','支持企业家(次)数'])
datalist.append(data)
#将所有表格连接在一起
result = pd.concat(datalist, join='inner', axis=1)
result.fillna(0.00, inplace=True)
#将求和结果和对应的行索引存入到字典中:dic[指标]=sum
index = result.columns
index1=index[:10]
for strs in index1:
#按照行进行求和