鱼C论坛

 找回密码
 立即注册
查看: 3212|回复: 3

如何将一个工作簿中的多个工作表拆分

[复制链接]
发表于 2023-5-11 09:15:00 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
求助:如何将一个工作簿中的多个工作表按照每个表中的字段拆分成多个工作簿,且每个工作簿里面对应的工作表名称和原工作簿的里面的工作表名称保持一致。
例如: 7089b13ecd34526bcb95f6a5598a8aa.png 图片中的工作簿中包含了5个工作表,现在要将这5个工作表都按照D列区域字段拆分成8个工作簿,然后每个新工作簿中就只包含了每个区域的数据,同时新工作簿中也要5个子工作表且工作表的名称和原工作簿保持一致。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2023-5-11 09:15:36 | 显示全部楼层
可以使用VBA宏来实现这个功能。

首先需要打开Visual Basic编辑器,在工程资源管理器中右键点击该工作簿,选择插入->模块,然后在模块中输入以下代码:
  1. Sub SplitWorkbook()
  2.     Dim wb As Workbook
  3.     Dim ws As Worksheet
  4.     Dim newWB As Workbook
  5.     Dim newWS As Worksheet
  6.     Dim lastRow As Long
  7.     Dim i As Long
  8.    
  9.     Set wb = ThisWorkbook
  10.    
  11.     For Each ws In wb.Worksheets
  12.         lastRow = ws.Cells(Rows.Count, "D").End(xlUp).Row
  13.         For i = 2 To lastRow
  14.             ' Check if new workbook needs to be created
  15.             If newWB Is Nothing Or ws.Cells(i, "D").Value <> newWS.Cells(2, "D").Value Then
  16.                 ' Create new workbook and copy worksheet
  17.                 Set newWB = Workbooks.Add
  18.                 ws.Copy Before:=newWB.Worksheets(1)
  19.                 Set newWS = newWB.Worksheets(1)
  20.                 newWS.Name = ws.Cells(i, "D").Value
  21.             End If
  22.             
  23.             ' Copy row to new worksheet
  24.             ws.Rows(i).Copy newWS.Rows(newWS.Cells(Rows.Count, "A").End(xlUp).Row + 1)
  25.         Next i
  26.         
  27.         ' Save new workbook
  28.         newWB.SaveAs Filename:=wb.Path & "" & ws.Name & ".xlsx", FileFormat:=xlOpenXMLWorkbook
  29.         newWB.Close SaveChanges:=False
  30.         Set newWB = Nothing
  31.     Next ws
  32. End Sub
复制代码

然后在工作簿中按下Alt+F8,选择SplitWorkbook,并点击运行。

这个宏会遍历每个工作表,然后按照D列区域字段将每个工作表拆分成多个工作簿,每个新工作簿中包含了每个区域的数据,同时新工作簿中也有5个子工作表且工作表的名称和原工作簿保持一致。最后每个新工作簿都会保存在原工作簿的同一目录下。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-5-11 09:19:09 | 显示全部楼层
要实现这个需求,我们可以使用Python的pandas库和openpyxl库。Pandas用于处理和操作数据,而openpyxl则用于操作Excel文件。以下是具体的步骤:

首先,安装所需的库。在你的Python环境中,运行以下命令安装pandas和openpyxl:

  1. pip install pandas openpyxl
复制代码


然后,这是一个简单的Python脚本,它将读取你的Excel工作簿,按照D列的区域字段拆分工作表,然后将每个区域的数据写入新的工作簿。

  1. import pandas as pd
  2. import os

  3. # 读取Excel文件
  4. xlsx = pd.ExcelFile('your_file.xlsx')

  5. # 从Excel文件中获取工作表的名称
  6. sheet_names = xlsx.sheet_names

  7. # 创建一个字典来存储每个区域的DataFrame
  8. dfs_dict = {}

  9. for sheet_name in sheet_names:
  10.     # 读取工作表中的数据
  11.     df = xlsx.parse(sheet_name)
  12.    
  13.     # 获取区域列表
  14.     regions = df['D'].unique()

  15.     for region in regions:
  16.         # 根据区域拆分DataFrame
  17.         df_region = df[df['D'] == region]
  18.         
  19.         # 将拆分后的DataFrame存储到字典中
  20.         if region not in dfs_dict:
  21.             dfs_dict[region] = {sheet_name: df_region}
  22.         else:
  23.             dfs_dict[region][sheet_name] = df_region

  24. # 根据字典创建新的Excel文件
  25. for region, dfs in dfs_dict.items():
  26.     # 创建Excel写入器
  27.     writer = pd.ExcelWriter(f'{region}.xlsx', engine='openpyxl')

  28.     for sheet_name, df in dfs.items():
  29.         # 将DataFrame写入Excel文件
  30.         df.to_excel(writer, sheet_name=sheet_name, index=False)

  31.     # 保存Excel文件
  32.     writer.save()
复制代码


以上脚本假设你的Excel文件名为 'your_file.xlsx',并且你要根据的区域字段位于列 'D'。如果实际情况不同,需要修改对应的部分。同样,生成的新工作簿将以区域名命名,保存在Python脚本相同的目录下。

在运行此脚本之前,确保你的Python环境有足够的权限访问和修改这个目录。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-5-11 09:19:35 From FishC Mobile | 显示全部楼层
isdkz 发表于 2023-5-11 09:15
可以使用VBA宏来实现这个功能。

首先需要打开Visual Basic编辑器,在工程资源管理器中右键点击该工作簿, ...

python一样能实现,不过你这个明显是ai
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-29 03:13

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表