VBS 批量读取文件夹内所有的文本到Excel的脚本
来源: 阅读:1776 次 日期:2016-07-18 11:52:39
温馨提示: 小编为您整理了“VBS 批量读取文件夹内所有的文本到Excel的脚本”,方便广大网友查阅!

VBS批量读取文件夹内所有的文本到Excel,有需要的朋友可以参考下。

代码如下:

'This code is done by KangKang@

Option explicit ‘This is optional, but better to use.

Dim FolderPath,Folder

Dim fso,File,Files

Dim fileNums

Dim FileString()

Dim i

Dim ii

i=0

FolderPath="E:\TDDOWNLOAD\aa\"

'**********************1.To create the FileSystemObject object********************************

Set fso= CreateObject("Scripting.FileSystemObject")'This is the way to create FileSystemObjecy

‘这句话在Excel VBA中也可以如此定义来引用FSO!

'Scripting是类库的名字,filesystemobject是所引用的对 '象, 说明了此时VBA所用的对象不是自带的,而是引用 '外界的。

'**********************2.To create the Folder and File object*********************************

If fso.FolderExists(FolderPath) Then

Set Folder = fso.GetFolder(FolderPath) 'This set command is neccessary!

Set Files=Folder.Files

fileNums=Files.Count

'Msgbox fileNums

For Each File In Folder.Files

if right(File.name,2)="rm" then

ReDim Preserve FileString(i) 'This is a Dynamic Array, so we should use the Redim command

'Be careful of the Preserve word, important!!!!

FileString(i)=File.Name

'MsgBox i & " " & FileString(i)

i=i+1

fileNums=i

End if

Next

End If

'**********************3.Create Excel and stroe the file name in it***************************

Dim objExcel

Dim objWorkbook

Set objExcel = WScript.CreateObject("Excel.Application")

objExcel.Workbooks.Add

objExcel.Visible=True

Set objWorkbook = objExcel.ActiveWorkbook

For ii=1 to fileNums

objWorkbook.Worksheets(1).Cells(ii,1)=FileString(ii-1)

Next

objWorkbook.Worksheets(1).Range("A1:A1").Columns.AutoFit

objExcel.DisplayAlerts = False

objWorkbook.SaveAs(FolderPath & "xiao.xls")

objWorkbook.Close()'Close the Workbook

objExcel.Quit()'Quit

Set fso=Nothing

'**********************4.Open the files and read the first line.******************************

Dim Range

Dim Range_i

Dim mfile

Dim sline

Dim iii

set fso=createobject("scripting.filesystemobject")

Set objExcel = WScript.CreateObject("Excel.Application")

objExcel.Visible=True

objExcel.Workbooks.open(FolderPath & "xiao.xls")

Set objWorkbook = objExcel.ActiveWorkbook

Set Range = objWorkbook.Activesheet.range("A1:A11")

For Range_i=1 to fileNums

set mfile=fso.opentextfile(Range(Range_i).value)

msgbox Range_i & " " & Range(Range_i).value

for iii=1 to 1

sline=mfile.readline

objWorkbook.Worksheets(1).Cells(Range_i,2)=sline

Next

mfile.close

Next

objWorkbook.Worksheets(1).Range("B1:B1").Columns.AutoFit

objExcel.DisplayAlerts = False

objWorkbook.SaveAs(FolderPath & "xiao.xls")

objWorkbook.Close()'Close the Workbook

objExcel.Quit()'Quit

Set fso=Nothing

更多信息请查看脚本栏目
由于各方面情况的不断调整与变化, 提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!
关于我们 | 联系我们 | 人才招聘 | 网站声明 | 网站帮助 | 非正式的简要咨询 | 简要咨询须知 | 加入群交流 | 手机站点 | 投诉建议
工业和信息化部备案号:滇ICP备2023014141号-1 云南省教育厅备案号:云教ICP备0901021 滇公网安备53010202001879号 人力资源服务许可证:(云)人服证字(2023)第0102001523号
云南网警备案专用图标
联系电话:0871-65317125(9:00—18:00) 获取招聘考试信息及咨询关注公众号:
咨询QQ:526150442(9:00—18:00)版权所有:
云南网警报警专用图标
Baidu
map