博客
关于我
使用VBA合并多个TXT文件内容到Excel的不同列的实现
阅读量:160 次
发布时间:2019-02-27

本文共 2530 字,大约阅读时间需要 8 分钟。

目录

需求

某一文件夹下有多个txt文件,文件里每行是一个内容,类似:

data1.txt

12345

data2.txt

abcde

最终需要把这些txt内容复制到excel里,并存在同一个sheet的不同列里

编码

Sub AddWorkbook()    'sub表示一个过程    '声明一个变量    Dim isSheetOk  As Boolean    '调用一个叫做copyTXT2Sheet的函数    isSheetOk = copyTXT2Sheet()    If Not isSheetOk Then        Exit Sub    End If    ' 保存结果    saveResult            End SubFunction copyTXT2Sheet() As Boolean '函数返回一个布尔值,函数返回值即  函数名=xxx 则表示返回了 xxx    Dim resultName As String    Dim xFile As String    Dim xFileDialog As FileDialog    Dim xToBook As Workbook    Dim xWb As Workbook    Dim xFiles As New Collection    '文件选择弹窗    Set xFileDialog = Application.FileDialog(msoFileDialogFolderPicker)    xFileDialog.AllowMultiSelect = False    xFileDialog.Title = "选择包含txt的文件夹"    If xFileDialog.Show = -1 Then        xStrPath = xFileDialog.SelectedItems(1)    End If    If xStrPath = "" Then        copyTXT2Sheet = False        Exit Function    End If    If Right(xStrPath, 1) <> "\" Then        xStrPath = xStrPath & "\"    End If    '获取文件夹下的*.txt文件    xFile = Dir(xStrPath & "*.txt")    If xFile = "" Then        MsgBox "No files found", vbInformation, "Kutools for Excel"        copyTXT2Sheet = False        Exit Function    End If    Do While xFile <> ""        xFiles.Add xFile '读取到的文件路径存入集合        xFile = Dir() ' 使用Dir不断访问下个文件,直到没文件    Loop    ' 新建一个excel文件    Set xToBook = Workbooks.Add    If xFiles.Count > 0 Then        For i = 1 To xFiles.Count            '读取txt转换成excel,使用utf编码打开(解决中文乱码问题)            Workbooks.OpenText Filename:=xStrPath & xFiles.Item(i), Origin:=65001            '复制读取的第一列依次到新建excel的列            Worksheets(1).Range("A:A").Copy xToBook.Sheets(xToBook.Sheets.Count).Columns(i)            '设置列宽随内容自适应            xToBook.Sheets(xToBook.Sheets.Count).Columns(i).EntireColumn.AutoFit            ' 关闭打开的txt转excel文件,false表示no save change            Workbooks(xFiles(i)).Close False        Next    End If        'resultName = getCurrentTime() & "_合并结果"    'xToBook.SaveAs (resultName)        copyTXT2Sheet = True    End FunctionFunction saveResult()        With Application.FileDialog(msoFileDialogSaveAs)        .Title = "选择路径保存结果"        .ButtonName = "保存"        .InitialFileName = getCurrentTime() & "_合并结果"        If .Show = 0 Then            MsgBox "文件未保存", vbCritical            Exit Function        End If        Application.DisplayAlerts = False        .Execute        Application.DisplayAlerts = True            End With            End FunctionFunction getCurrentTime()    getCurrentTime = Format(Now(), "YYYY-mm-dd-HH_MM_SS")End Function

结果

在这里插入图片描述

转载地址:http://flbd.baihongyu.com/

你可能感兴趣的文章
NIFI大数据进阶_离线同步MySql数据到HDFS_02_实际操作_splitjson处理器_puthdfs处理器_querydatabasetable处理器---大数据之Nifi工作笔记0030
查看>>
NIFI大数据进阶_离线同步MySql数据到HDFS_说明操作步骤---大数据之Nifi工作笔记0028
查看>>
NIFI大数据进阶_连接与关系_设置数据流负载均衡_设置背压_设置展现弯曲_介绍以及实际操作---大数据之Nifi工作笔记0027
查看>>
NIFI数据库同步_多表_特定表同时同步_实际操作_MySqlToMysql_可推广到其他数据库_Postgresql_Hbase_SqlServer等----大数据之Nifi工作笔记0053
查看>>
NIFI汉化_替换logo_二次开发_Idea编译NIFI最新源码_详细过程记录_全解析_Maven编译NIFI避坑指南001---大数据之Nifi工作笔记0068
查看>>
NIFI汉化_替换logo_二次开发_Idea编译NIFI最新源码_详细过程记录_全解析_Maven编译NIFI避坑指南002---大数据之Nifi工作笔记0069
查看>>
NIFI集群_内存溢出_CPU占用100%修复_GC overhead limit exceeded_NIFI: out of memory error ---大数据之Nifi工作笔记0017
查看>>
NIFI集群_队列Queue中数据无法清空_清除队列数据报错_无法删除queue_解决_集群中机器交替重启删除---大数据之Nifi工作笔记0061
查看>>
NIH发布包含10600张CT图像数据库 为AI算法测试铺路
查看>>
Nim教程【十二】
查看>>
Nim游戏
查看>>
NIO ByteBuffer实现原理
查看>>
Nio ByteBuffer组件读写指针切换原理与常用方法
查看>>
NIO Selector实现原理
查看>>
nio 中channel和buffer的基本使用
查看>>
NIO_通道之间传输数据
查看>>
NIO三大组件基础知识
查看>>
NIO与零拷贝和AIO
查看>>
NIO同步网络编程
查看>>
NIO基于UDP协议的网络编程
查看>>