excel合并工作博

复制代码
Sub MergeSelectedFilesIntoCurrentWorkbook()
    Dim ws As Worksheet
    Dim wb As Workbook
    Dim targetWorkbook As Workbook
    Dim fileNames As Variant
    Dim i As Integer
    Dim sheet As Worksheet
    Dim csvWs As Worksheet
    
    ' 选择文件
    fileNames = Application.GetOpenFilename(FileFilter:="Excel Files (*.xls*), *.xls*; CSV Files (*.csv), *.csv", _
                                            Title:="选择要合并的Excel/CSV文件", _
                                            MultiSelect:=True)
                                            
    ' 如果没有选择文件,则退出
    If IsArray(fileNames) = False Then
        MsgBox "没有选择文件,操作取消。"
        Exit Sub
    End If
    
    ' 禁用屏幕更新以提高速度
    Application.ScreenUpdating = False
    
    ' 设置当前工作簿
    Set targetWorkbook = ThisWorkbook
    
    ' 循环遍历选择的文件
    For i = LBound(fileNames) To UBound(fileNames)
        ' 根据文件扩展名进行处理
        If Right(fileNames(i), 4) = ".csv" Then
            ' 处理CSV文件
            Set wb = Workbooks.Open(fileNames(i))
            Set csvWs = wb.Sheets(1)
            csvWs.Copy After:=targetWorkbook.Sheets(targetWorkbook.Sheets.Count)
            wb.Close False
        ElseIf Right(fileNames(i), 4) = "xlsx" Or Right(fileNames(i), 4) = ".xls" Then
            ' 处理Excel文件
            Set wb = Workbooks.Open(fileNames(i))
            For Each sheet In wb.Sheets
                sheet.Copy After:=targetWorkbook.Sheets(targetWorkbook.Sheets.Count)
            Next sheet
            wb.Close False
        End If
    Next i
    
    ' 重新启用屏幕更新
    Application.ScreenUpdating = True
    
    MsgBox "所有选定的文件已成功合并到当前工作簿中。"
End Sub
  1. 文件选择Application.GetOpenFilename 方法允许选择 .xls, .xlsx, 和 .csv 文件。MultiSelect:=True 允许一次选择多个文件。

  2. 文件类型判断:代码通过检查文件的扩展名来决定如何处理:

    • CSV文件:打开文件后,只包含一个工作表,因此直接复制该工作表到目标工作簿中。
    • Excel文件 :对于 .xls.xlsx 文件,代码将遍历所有工作表并复制到目标工作簿。
  3. 文件关闭:在处理完每个文件后,源文件将被关闭以释放资源。

使用方法

  1. 打开目标工作簿。
  2. ALT + F11 打开VBA编辑器。
  3. 插入新模块 (Insert > Module) 并粘贴代码。
  4. 运行宏 (F5 键),选择你需要合并的Excel/CSV文件。

注意事项

  • CSV文件的格式:CSV文件通常只包含数据,没有格式或公式。当它们被合并时,数据将被直接复制到目标工作簿中,格式将使用默认的工作表格式。
  • 重复工作表名称:如果目标工作簿中已有相同名称的工作表,Excel将自动重命名新复制的工作表(如 "Sheet1 (2)"),以避免名称冲突。
相关推荐
LAM LAB9 天前
【VBA】Excel指定单元格范围内字体设置样式,处理导出课表单元格
excel·vba
在这habit之下9 天前
Keepalived学习总结
excel
Youngchatgpt10 天前
如何在 Excel 中使用 ChatGPT:自动化任务和编写公式
人工智能·chatgpt·自动化·excel
开开心心就好10 天前
安卓开源应用,超时提醒紧急人护独居安全
windows·决策树·计算机视觉·pdf·计算机外设·excel·动态规划
D_C_tyu10 天前
Vue3 + Element Plus | el-table 多级表头表格导出 Excel(含合并单元格、单元格居中)第二版
vue.js·elementui·excel
骆驼爱记录10 天前
WPS页码设置:第X页共Y-1页
自动化·word·excel·wps·新人首发
Cxiaomu11 天前
Python 文件解析: Excel / Word / PDF 的解析、处理、预览与下载
python·word·excel
2501_9307077811 天前
如何使用C#代码从 PDF 中提取表格并另存为Excel文件
pdf·excel
pacong11 天前
B生所学EXCEL
人工智能·excel