python与excel第七节 拆分工作簿

一个工作簿中多个工作表拆分为多个工作簿

假设一个excle工作簿中有多个工作表,现在需要将每个工作表拆分为单独的工作簿。

例子:

import xlwings as xw
# 设置生成文件的路径
path = 'D:\\TEST\\dataIn'
# 源文件的路径
workbook_name = 'D:\\TEST\\dataIn\\产品表.xlsx'
app = xw.App(visible=False, add_book=False)
# 打开源文件
workbook = app.books.open(workbook_name)
# 遍历来源工作簿中的工作表
for i in workbook.sheets:
# 新建一个目标工作簿 workbook_split = app.books.add()
# 选择目标工作簿中的第一个工作表 sheet_split = workbook_split.sheets[0]
# 将来源工作簿中的当前工作表复制到目标工作簿的第一个工作表之前 i.api.Copy(Before=sheet_split.api)
# 输出文件,并命名 workbook_split.save(path + '\\{}.xlsx'.format(i.name))
app.quit()

一个工作表按条件拆分为多个工作表

假设一个工作表中有很多数据,现在需要根据某一列将其分类到不同的sheet里面。

例子:

import xlwings as xw
import pandas as pd

app = xw.App(visible=True,add_book=False)
workbook = app.books.open('D:\\TEST\\dataIn\\产品表.xlsx')
worksheet = workbook.sheets['厨具']
# 读取要拆分的工作表数据
value = worksheet.range('A1').options(pd.DataFrame,header=1,index=False,expand='table').value
# 将数据按照 " 品牌 " 拆分, value.groupby() 返回的两个参数:组名 (str 类型 ) ,组的内容( DataFrame 类型)
data = value.groupby('品牌')
for idx,group in data:
# 以品牌名称为工作簿中新增工作表命名 new_worksheet = workbook.sheets.add(idx)
new_worksheet['A1'].options(index=False).value=group # 数据添加到新增的工作表
workbook.save()
workbook.close()
app.quit()

一个工作表的数据拆分到多个工作簿

假设一个工作表中有很多数据,现在需要根据某一列将其分类到不同的工作簿里面。

例子:

import xlwings as xw
# 读取源表数据到字典中,再根据 key 分类读取生成工作簿
out_path = 'D:\\TEST\\dataIn\\'
file_path = 'D:\\TEST\\dataIn\\产品表.xlsx'
sheet_name = '厨具'
app = xw.App(visible=True,add_book=False)
workbook = app.books.open(file_path)
worksheet = workbook.sheets[sheet_name]
# 从第二行开始时数据
value = worksheet.range('A2').expand('table').value

data = dict()
for i in range(len(value)):
# 根据第 2 列进行分类 brand_name = value[i][2]
# 如果字典中没有该名称的产品,就新建一个 if brand_name not in data:
data[brand_name] = []
data[brand_name].append(value[i])
print(data)
for key,value in data.items():
new_workbook = xw.books.add()
# 根据品牌为 sheet 名创建工作表 new_worksheet = new_workbook.sheets.add(key)
# 先复制列标题到新建工作表中 new_worksheet['A1'].value = worksheet['A1:D1'].value
# 复制数据到新建工作表中 new_worksheet['A2'].value = value
new_workbook.save(out_path + '{}.xlsx'.format(key))
app.quit()

相关推荐
安思派Anspire1 分钟前
LangGraph + MCP + Ollama:构建强大代理 AI 的关键(二)
人工智能·后端·python
站大爷IP5 分钟前
Python文件与目录比较全攻略:从基础操作到性能优化
python
人生在勤,不索何获-白大侠16 分钟前
day16——Java集合进阶(Collection、List、Set)
java·开发语言
LIN-JUN-WEI34 分钟前
[ESP32]VSCODE+ESP-IDF环境搭建及blink例程尝试(win10 win11均配置成功)
c语言·开发语言·ide·vscode·单片机·学习·编辑器
望获linux1 小时前
【Linux基础知识系列】第四十三篇 - 基础正则表达式与 grep/sed
linux·运维·服务器·开发语言·前端·操作系统·嵌入式软件
ahead~1 小时前
【大模型入门】访问GPT_API实战案例
人工智能·python·gpt·大语言模型llm
留不住丨晚霞2 小时前
说说SpringBoot常用的注解?
java·开发语言
大模型真好玩2 小时前
准确率飙升!GraphRAG如何利用知识图谱提升RAG答案质量(额外篇)——大规模文本数据下GraphRAG实战
人工智能·python·mcp
19892 小时前
【零基础学AI】第30讲:生成对抗网络(GAN)实战 - 手写数字生成
人工智能·python·深度学习·神经网络·机器学习·生成对抗网络·近邻算法
hardStudy_h2 小时前
C++——内联函数与Lambda表达式
开发语言·jvm·c++