百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

Excel VBA 文件批量改名/获取文件夹路径/获取文件夹下所有文件

liuian 2025-02-06 15:41 47 浏览

本文于2023年2月26日首发于本人同名公众号:Excel活学活用,敬请关注!

前些天在听一个课程的MP3,它每一课有2个文件,大概是这样子“001-朗读.MP3" 和“001-讲解.MP3",在播放列表中,这两个文件的顺序是讲解在前,朗读在后,应该是先朗读再讲解,那么解决办法是把文件改名,比如改成这样“001-1朗读.MP3" 和“001-2讲解.MP3",但文件太多,一个一个手工去改实在太累,有没有其他办法呢?

经过一番沉思,感觉可以有!

废话不多说,直接上代码:

在sheet1里,插入3个命令按钮,并输入代码:

Private Sub CmdClear_Click()
    ActiveSheet.Cells.ClearContents
End?Sub


Private Sub CommandButton1_Click()
    Call OldNames
?End?Sub


Private Sub CommandButton2_Click()
    Call ChangeNames
End?Sub

在模块1里:

Dim arrFiles()
Dim iPath As String
Sub?OldNames()
    iPath = PathSelected()
    If iPath = "" Then
        MsgBox "文件路径异常,请重新读取文件!"
        Exit Sub
    End If
    arrFiles = GetSubFiles(iPath)
    Sheet1.Range("A:A").Clear
    Sheet1.Range("A3").Resize(UBound(arrFiles) + 1, 1) = Application.WorksheetFunction.Transpose(arrFiles)
    Sheet1.Range("A1") = "文件夹:"
    Sheet1.Range("B1") = iPath
    Sheet1.Range("A2") = "原文件名"
    Sheet1.Range("B2") = "新文件名"
End Sub
Sub ChangeNames()
    Dim iRow
    Dim oFSO
    Dim oFolder
    Dim oFile
    Dim OldName$
    Set oFSO = CreateObject("Scripting.FileSystemObject")
    iRow = Sheet1.UsedRange.Rows.Count
    arrFiles = Sheet1.Range("A3:B" & iRow)
    '检查新文件名有没有空白的
    For i = 1 To UBound(arrFiles, 1)
        If arrFiles(i, 1) <> "" Then
            If arrFiles(i, 2) = "" Then
                MsgBox "第" & i & "行有空文件名,请重新检查修改!"
??????????????????Exit?Sub
            End If
        End If
?????Next
??????'开始改名
    For i = 1 To UBound(arrFiles, 1)
        If arrFiles(i, 1) <> "" Then
            OldName = Sheet1.Range("B1") & "\" & arrFiles(i, 1)
            If oFSO.fileexists(OldName) Then
                Set oFile = oFSO.GetFile(OldName)
????????????????If?oFile.Name?<>?arrFiles(i,?2)?Then??
                    oFile.Name = arrFiles(i, 2)
                End If
            End If  
        End If
    Next
    MsgBox "批量改名成功"
End Sub
Function GetSubFiles(iPath As String)
    Dim FSO As Object, SFolder, fl
    Dim arr()
    Set FSO = CreateObject("Scripting.FileSystemObject")
    Set SFolder = FSO.GetFolder(iPath)
    For Each fl In SFolder.Files
        i = i + 1
        ReDim Preserve arr(i - 1)
        arr(i - 1) = fl.Name
??????Next
    GetSubFiles = arr
End?Function
Function PathSelected()
    With Application.FileDialog(msoFileDialogFolderPicker)
?????????If?.Show?=?-1 Then ??????????????????????'FileDialog 对象的 Show 方法显示对话框,并且返回?-1(如果按 OK)和?0(如果按 Cancel)。
            PathSelected = .SelectedItems(1)
        Else
            Exit Function
??????????End?If
    End With
End?Function

简单解释一下代码:

基本思路:把要修改名称的文件名读取到sheet1表的A列,然后在B列根据需要对应修改成想要的文件名,这里可以充分利用Excel的查找替换、公式函数等功能,方便地形成想要的文件名。然后运行一段代码,逐个把A列的文件名改名为B列的文件名。

如何获取要修改的文件名?

这里假定是在一个文件夹下进行操作,那么,我们可以做两件事,第一,先取得文件夹路径,然后再取得该文件夹下所有文件的名称。这里我们定义了两个自定义函数,Function PathSelected(); Function GetSubFiles(iPath As String),实现需求的功能。

取得文件名后,同时也把路径记录下来,填在“B1"单元格,便于查看,防止搞错了,这里还是要提醒一下,此操作不可恢复,操作前请看仔细,重要文件要做好备份!!!当然,要想实现恢复的功能也不是什么难事,把新旧文件名对照表复制保存到另外一张表上,要恢复的时候,把文件名对调一下,执行批量改名即可,这里不再多说,各位自行发挥。

接下来,就是把对应的新文件名处理好,点击“批量改名”按钮,大功告成。

另外,两个自定义函数(取得文件夹路径、取得文件夹下所有文件名)用处广泛,可以保存备用,实际上我在写这玩意的时候,就是从别的文件里Copy过来的,啥都没改,直接使用上了。

好,今天就到这,示例文件下载地址附在文后,感兴趣的自取不谢。

祝各位一切安好,如果是初学VBA的同学,我们可以多多交流。

链接:
https://pan.baidu.com/s/1IrKmoEiLvlfkw3qXMCJ8hg?pwd=kk7q

提取码:kk7q

本文于2023年2月26日首发于本人同名公众号:Excel活学活用,敬请关注!

相关推荐

平板电脑一键root工具(平板电脑 root)

1、下载APP:ROOT大师;2、打开小米平板USB调试模式;3、安装驱动,提示连接成功4、获取ROOT权限。5、显示更新成功后依次选择:返回-重新启动-系统6、重启后打开桌面的super...

autocad2010激活码怎么获取(cad2010最新激活码密钥免费领取)
  • autocad2010激活码怎么获取(cad2010最新激活码密钥免费领取)
  • autocad2010激活码怎么获取(cad2010最新激活码密钥免费领取)
  • autocad2010激活码怎么获取(cad2010最新激活码密钥免费领取)
  • autocad2010激活码怎么获取(cad2010最新激活码密钥免费领取)
手机u盘驱动器下载(手机u盘驱动器下载安装)

不能直接手机下载到u盘,可以下到手机,然后手机连电脑copy到u盘你只需把你心爱的U盘插到电脑上,然后它会有一个新硬安装向导当它要搜索驱动程序时,你只需将其浏览到你所下载的usb万能驱动文件夹点下...

组装电脑配置价格表(组装电脑顶级配置清单及价格)
  • 组装电脑配置价格表(组装电脑顶级配置清单及价格)
  • 组装电脑配置价格表(组装电脑顶级配置清单及价格)
  • 组装电脑配置价格表(组装电脑顶级配置清单及价格)
  • 组装电脑配置价格表(组装电脑顶级配置清单及价格)
旺旺下载app(旺旺下载链接是多少)

可以下载多换几个下载软件试试直接登录官方appstore里面下载就可以使用了。1、首先在手机中找到appstore。2、点击进入后,在上方的搜索条里输入“阿里旺旺”,选中官方的阿里旺旺。3、点击进...

主机显卡在哪个位置(主机显卡在哪个位置看)

1、集成显卡的位置一般在机箱后面的中部,插口是竖立的。独立显卡的位置一般在机箱后面的下部,插口是横平的。2、独立显卡,一般插在主板中部的插槽,用手可以直接拔出。如果分不清哪个是显卡的插口,就直接看显示...

windows7ultimate下载(windows7 ultimate)

要下载澪Ultimate启动器,您可以按照以下步骤进行操作:1.打开您的网络浏览器,访问澪Ultimate启动器的官方网站或相关下载页面。2.在网站上找到适用于您的操作系统的下载选项。3.点击下...

苹果首次激活时间查询(iphone激活查询官网入口)

登陆苹果官网输入手机的序列号,查看手机的保修日期就可以了,一般保修到期的前一年就是手机的开机激活时间。查看第一次开机激活时间操作方法:1、首先打开设置2、点击通用3、点击关于本机...

u盘启动哪个好用(u盘启动盘哪个最好)

大白菜超级U盘启动盘制作工具,打造你真正的万能U盘!安装后你在U盘里是看到什么文件的,是隐藏分区,这样你放存别的东西时也不会搞乱了。大白菜超级U盘启动盘制作工具,是纯傻瓜式制作U盘启动盘功能的超级万能...

腾达路由器高级设置在哪里(腾达路由器怎么设置安全性高)

方法/步骤分步阅读1/11打开新购的腾达路由器,查看路由器背面的默认IP和管理员密码。小提示:密码为:admin默认管理IP:192.168.0.12/11接好腾达路由器和插上电源通电,等待2-3分钟...

dell新版bios设置恢复(戴尔bios恢复设置)

1)、开机后,在看到DELL图标时,按3下F2,进入BIOS。(灰色界面)2)、分别按键盘上的CapsLock,ScrollLock,以及NumLock三个键,使键盘上相应的三个指示灯点亮。3)、...

重装win7系统需要多少钱(重装一个win7系统要多少钱)

1、win7系统装完后需要占用C盘空间10-15GB,如果把常用软件也安装到C盘,大小超过20+。  2、在分区的时候根据硬盘大小,如果硬盘相对较小,一般建议设置50G,最低不能低于30G。因...

性价比笔记本推荐2025(性价比高的笔记本电脑2021年)

2023年联想推出的一款性价比高的笔记本电脑是联想Yoga7Carbon。它是一款轻薄便携的2合1笔记本,采用了高强度碳纤维材质打造,具有出色的抗撞击性和高端外观。配备了英特尔第11代酷睿处理器、...

华为和联想平板哪个好(华为平板和联想平板对比)

联想,是典型的组装厂,CPU不能造,屏幕不能造.而华为,拥有核心技术,大量有价值专利的,比如说:华为mediapad平板电脑小巧轻薄,7英寸便携机身让她成为出行必备,新推出的粉红炫彩版更集美貌与智慧于...

电脑桌面壁纸原始经典(电脑桌面壁纸原图下载)
  • 电脑桌面壁纸原始经典(电脑桌面壁纸原图下载)
  • 电脑桌面壁纸原始经典(电脑桌面壁纸原图下载)
  • 电脑桌面壁纸原始经典(电脑桌面壁纸原图下载)
  • 电脑桌面壁纸原始经典(电脑桌面壁纸原图下载)