使用Python拆分Excel工作表
excelperfect
标签:Python与Excel,pandas
才开通星空问答,就收到了小几个问题,试着回答了,不知道满不满意,相信随着水平的增长,会让大家更加满意的。相关链接>>>Excel与VBA,还有相关的Python,到这里来问我
其中有一个问题是:
如何用Python按照某列的关键词分拆工作表,并保留表中原有的公式。
由于星空问答的功能还在完善中,不能上传图片和示例文件,并且我觉得这个问题正好可以检验一下近半个月学习Python与Excel相关知识的效果,于是自己编了一个示例,试了一下,感觉使用Python来实现一些任务确实很简洁。在这里,与大家分享,也请高手们指点。
示例工作表
为演示起见,我制作了一个简单的工作表,如下图1所示。
图1
这里,假设这个工作表所在工作簿的名字是“拆分示例.xlsx”,并且根据列C中的分类来拆分工作表,有两个分类:建设项目和电商,因此应该拆分成两个工作表。此外,列F是计算列,其中包含有公式。
拆分到两个工作簿
代码很简单:
import pandas as pd
df = pd.read_excel(r'D:\拆分示例.xlsx')
df1 = df.loc[df['分类'] == '建设项目']
df2 = df.loc[df['分类'] == '电商']
df1.to_excel(r'D:\建设项目.xlsx',index= False)
df2.to_excel(r'D:\电商.xlsx',index = False)
将该工作表按分类拆分成了两个工作表,并放置到两个新工作簿“建设项目.xlsx”和“电商.xlsx”中。
拆分到同一工作簿中的两个工作表
代码如下:
import pandas as pd
df = pd.read_excel(r'D:\拆分示例.xlsx')
df1 = df.loc[df['分类'] == '建设项目']
df2 = df.loc[df['分类'] == '电商']
writer1 = pd.ExcelWriter(r'D:\拆分示例.xlsx')
df1.to_excel(writer1, sheet_name = '建设项目', index =False)
df2.to_excel(writer1, sheet_name = '电商', index =False)
writer1.save()
下面,我们将代码进一步优化。
使用列表
代码如下:
import pandas as pd
df = pd.read_excel(r'D:\拆分示例.xlsx')
cat = ['建设项目', '电商']
for subcat in cat:
myfile = df.loc[df['分类'] ==subcat]
myfile.to_excel('D:\\'+subcat+'.xlsx',index = False)
再进一步,我们不管分类列中有多个独立的分类,直接按分类生成工作表。代码如下:
import pandas as pd
df = pd.read_excel(r'D:\拆分示例.xlsx')
cat = df['分类'].unique()
for subcat in cat:
myfile = df.loc[df['分类'] ==subcat]
myfile.to_excel('D:\\'+subcat+'.xlsx',index = False)