Excel获取不同工作簿内相同名称的工作表

Excel获取不同工作簿内相同名称的工作表

好几年前处理工作单的时候用过,想起来也是相当久没有用过excel,也把一丢丢的VBA sense给丢了。再用的时候,头皮抓破也想不起要怎么写。

看了Excelhome看了百度看了CSDN,翻查了很久,终于找到个合适的代码,稍微改动即可使用,感谢作者,忘记链接了,如果作者看到,想要添加名或者链接,请留言告诉我。

Ctrl/Command + Shift + K

Sub GetExcleWS() ’获取不同工作簿内相同工作表并生成一个新工作表
    Dim path As String, filename As String
    Dim w As Workbook, ws As Workbook
    
    path = "C:\Users\Data Collect"
    filename = Dir(path & "\Summ_*.xlsx")  'ws 工作簿保存所有复制的工作表    
   Application.DisplayAlerts = False '提示关闭
    Set ws = Workbooks.Add
    
    Do While filename <> "" 
         Set w = Workbooks.Open(path & "\" & filename) ‘W 为文件夹内符合要求的工作簿
            w.Sheets("Summary").Copy After:=ws.Sheets(ws.Sheets.Count) ‘把选定的工作表复制
             '重命名刚贴的表名为excel文件名
            ws.Worksheets(ws.Sheets.Count).Name = Mid(filename, 1, Len(filename) - 5) 
        w.Close ’关闭工作簿
        filename = Dir ‘下一个工作簿
    Loop
    Application.DisplayAlerts = True
ws.SaveAs path & "\"Template_Data"&"ddmmyy.hhmmss"&.xlsx"  ’保存新工作簿
End Sub

没用过markdown编辑器,不懂怎么用。发出来试试。

用以存档


  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以使用Python库xlrd和xlsxwriter来实现这一功能。具体步骤如下:1. 导入xlrd和xlsxwriter模块:import xlrd,import xlsxwriter2. 使用xlrd读取excel:book = xlrd.open_workbook('example.xlsx')3. 获取所有工作簿名称:sheets = book.sheet_names()4. 使用xlsxwriter创建一个新的excel文件:workbook = xlsxwriter.Workbook('example.xlsx')5. 对每个工作簿遍历:for sheet in sheets:6. 使用xlsxwriter创建同名工作簿:worksheet = workbook.add_worksheet(sheet)7. 使用xlrd读取每个工作簿中的数据:data = xlrd.open_workbook('example.xlsx')8. 使用xlsxwriter将数据写入工作簿:worksheet.write(data)9. 保存excel文件:workbook.close() ### 回答2: 使用Python可以使用pandas库来自动逐个读取多个Excel的具有相同名称工作簿,并逐一存储于同样名称工作簿中。 首先,我们需要安装pandas库,可以使用pip安装,命令为:pip install pandas 然后,我们需要导入pandas库和os库,用于处理文件和目录的操作。代码如下所示: import pandas as pd import os 接下来,我们可以使用os库的listdir()函数来获取指定目录下的所有文件名。假设所有的Excel格都在一个名为"excel_files"的文件夹下,代码如下所示: file_folder = "excel_files" file_names = os.listdir(file_folder) 然后,我们可以使用for循环逐个读取所有的Excel格,并使用pandas库的read_excel()函数来读取每个格的内容。假设这些格都是xlsx格式的,代码如下所示: for file_name in file_names: if file_name.endswith(".xlsx"): file_path = os.path.join(file_folder, file_name) df = pd.read_excel(file_path) # 进行你想要的操作,比如修改数据或者保存到新的工作簿中 接下来,我们可以对读取到的数据进行相应的操作,比如修改数据或者保存到新的工作簿中。假设我们想要将读取到的数据保存到同样名称工作簿中,可以使用pandas库的to_excel()函数来保存到Excel文件。代码如下所示: new_file_name = file_name new_file_path = os.path.join(file_folder, new_file_name) df.to_excel(new_file_path) 通过以上步骤,我们就可以实现使用Python自动逐个读取多个Excel的具有相同名称工作簿,并逐一存储于同样名称工作簿中。 ### 回答3: 可以使用Python的openpyxl模块来实现逐个读取多个Excel格并存储到同样名称工作簿中。 首先,需要导入openpyxl模块: ```python import openpyxl ``` 然后,定义一个函数来读取Excel格: ```python def read_excel(file_name): workbook = openpyxl.load_workbook(file_name) sheet = workbook.active # 处理Excel格的内容 # 可以使用sheet的cells属性来遍历每个单元格 workbook.save(file_name) # 保存工作簿 workbook.close() # 关闭工作簿 ``` 接下来,可以使用glob模块找到所有的Excel文件路径,并调用之前定义的函数进行逐个读取和存储: ```python import glob # 获取所有Excel文件路径 file_paths = glob.glob('*.xlsx') # 逐个读取和存储Excel格 for file_path in file_paths: file_name = file_path.split('.')[0] # 提取文件名,不包括扩展名 read_excel(file_path) ``` 以上代码会逐个读取每个Excel格,并将它们存储到同样名称工作簿中。请注意,此处假设所有的Excel文件都是同一目录下的。 这样,Python就可以自动逐个读取多个Excel格,并将它们存储到同样名称工作簿中。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值