如何遍历文件夹下所有excel文件?

想把所有文件夹里的excel文件的空白sheet表都删掉,用VB代码怎么写?
或者判断每个sheet里B2单元格是否为空,如果是空的就删掉这个sheet,怎么写代码?

使用excel提取文件夹中的所有文件名称的方法主要有以下两个:
1、在那个文件夹内新建一个.TXT文件(如wenjian.txt),用记事本单开输入
dir> 1.txt
保存退出
将刚才的.TXT(wenjian.txt)更名为.bat文件(wenjian.bat)
双击wenjian.bat文件运行一次,在文件夹内多出一个1.txt文件
打开1.txt文件,将其中的内容粘贴到Excel中,数据——分列处理就可以得到你要的文件名列表了!
2、VBA(2003版)
在那个文件夹下新建Excel文件,打开新建的Excel文件,右击工作表标签(如Sheet1),查看代码——在代码编辑器中输入以下代码
Sub Test()
Dim i As Integer
Dim strPath As String
strPath = ThisWorkbook.Path
With Application.FileSearch
.LookIn = strPath
.SearchSubFolders = True
.Filename = "*.*"
If .Execute > 0 Then
For i = 1 To .FoundFiles.Count
Range("A" & i) = .FoundFiles(i)
Next i
End If
End With
End Sub
回到Excel表格中,工具——宏——宏——选择Sheet1.Test——执行

方法一简单的操作就可以,方法二需要对程序有一定的了解,方法二通用性比较强,需要的时候执行一下就可以,更快捷。
温馨提示:答案为网友推荐,仅供参考
第1个回答  推荐于2016-06-23
Private Sub Command1_Click()
    Dim FileName As String, FilePath As String
    Dim iFolder As Object, Xlapp As Object, Sh As Object
    Set iFolder = CreateObject("shell.application").BrowseForFolder(0, "", 0, "") 
    If iFolder Is Nothing Then Exit Sub 
    FilePath = iFolder.Items.Item.Path      
    FilePath = IIf(Right(FilePath, 1) = "\", FilePath, FilePath & "\")
    FileName = Dir(FilePath & "*.xls*")
    Set Xlapp = CreateObject("excel.application")
    Xlapp.displayalerts = False
    Do Until Len(FileName) = 0
        With Xlapp.workbooks.open(FilePath & FileName)
            For Each Sh In .WORKSHEETS
                If Len(Sh.RANGE("B2").Value) = 0 Then Sh.Delete
            Next
            .Close True
        End With
        FileName = Dir
    Loop
    Xlapp.quit
    Set Xlapp = Nothing
End Sub

本回答被提问者采纳

相关了解……

你可能感兴趣的内容

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 非常风气网