微博:@EXCELers / 知识星球:Excel

HI,大家好,我是星光。

这期给大家分享一下如何使用VBA代码获取多层文件夹下文件名……

什么意思呢?

比如说,A文件下有B文件夹,B文件夹下有C文件夹,C文件夹下又有D文件夹……

也就是传说中的子又生孙,孙又生子;子又有子,子又有孙;子子孙孙无穷匮也……

一键提取文件夹下所有文件名_如何一键提取文件夹名字_怎么一键提取文件名

示例代码如下:

代码如看不全,可以左右拖动..▼

Sub AutoAddLink()    Dim strFldPath As String    With Application.FileDialog(msoFileDialogFolderPicker)    '用户选择指定文件夹        .Title = "请选择指定文件夹。"        If .Show Then strFldPath = .SelectedItems(1) Else Exit Sub        '未选择文件夹则退出程序,否则将地址赋予变量strFldPath    End With    Application.ScreenUpdating = False    '关闭屏幕刷新    Range("a:b").ClearContents    Range("a1:b1") = Array("文件夹", "文件名")    Call SearchFileToHyperlinks(strFldPath)    '调取自定义函数SearchFileToHyperlinks    Range("a:b").EntireColumn.AutoFit    '自动列宽    Application.ScreenUpdating = True    '重开屏幕刷新End SubFunction SearchFileToHyperlinks(ByVal strFldPath As String) As String    Dim objFld As Object    Dim objFile As Object    Dim objSubFld As Object    Dim strFilePath As String    Dim lngLastRow As Long    Dim intNum As Integer    Set objFld = CreateObject("Scripting.FileSystemObject").GetFolder(strFldPath)    '创建FileSystemObject对象引用    For Each objFile In objFld.Files    '遍历文件夹内的文件        lngLastRow = Cells(Rows.Count, 1).End(xlUp).Row + 1        strFilePath = objFile.Path        intNum = InStrRev(strFilePath, "")        '使用instrrev函数获取最后文件夹名截至的位置        Cells(lngLastRow, 1) = Left(strFilePath, intNum - 1)        '文件夹地址        Cells(lngLastRow, 2) = Mid(strFilePath, intNum + 1)        '文件名        ActiveSheet.Hyperlinks.Add Anchor:=Cells(lngLastRow, 2), _                    Address:=strFilePath, ScreenTip:=strFilePath        '添加超链接    Next objFile    For Each objSubFld In objFld.SubFolders    '遍历文件夹内的子文件夹        Call SearchFileToHyperlinks(objSubFld.Path)    Next objSubFld    Set objFld = Nothing    Set objFile = Nothing    Set objSubFld = NothingEnd Function

代码使用了FileSystemObject对象和递归的方法实现文件夹和文件的遍历功能。分别将文件夹名称和文件名提取在表格的A/B列,并对文件名创建了超链接。

一键提取文件夹下所有文件名_怎么一键提取文件名_如何一键提取文件夹名字

打个响指……今天给大家分享的VBA小代码就这样……代码复制即可使用,文末下载模板点击按钮即可完成既定目标。

最后……提前祝大家这周末加班愉快……

案例文件下载百度网盘..▼

提取码: kn3y

需要系统学习Excel,却找不到优质教程?学习Excel的过程中遇到疑难问题,却找不到人及时作出解答?加入我的付费社群,这一切都不是问题……

从0到1、从入门到实战…

兼具图文/视频系统教程+微信群答疑…

技巧、函数、透视表、VBA、PQ、SQL

教程全覆盖,想学什么你就学什么……

推荐下方识别二维码加入我的知识星球▼

限时特惠:本站每日持续更新5-20节内部创业项目课程,一年会员
只需199元,全站资源免费下载点击查看详情
站长微信:
jjs406

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注