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

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

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

本文于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活学活用,敬请关注!

相关推荐

python入门到脱坑函数—定义函数_如何定义函数python

Python函数定义:从入门到精通一、函数的基本概念函数是组织好的、可重复使用的代码块,用于执行特定任务。在Python中,函数可以提高代码的模块性和重复利用率。二、定义函数的基本语法def函数名(...

javascript函数的call、apply和bind的原理及作用详解

javascript函数的call、apply和bind本质是用来实现继承的,专业点说法就是改变函数体内部this的指向,当一个对象没有某个功能时,就可以用这3个来从有相关功能的对象里借用过来...

JS中 call()、apply()、bind() 的用法

其实是一个很简单的东西,认真看十分钟就从一脸懵B到完全理解!先看明白下面:例1obj.objAge;//17obj.myFun()//小张年龄undefined例2shows(...

Pandas每日函数学习之apply函数_apply函数python

apply函数是Pandas中的一个非常强大的工具,它允许你对DataFrame或Series中的数据应用一个函数,可以是自定义的函数,也可以是内置的函数。apply可以作用于DataF...

Win10搜索不习惯 换个设定就好了_window10搜索用不了怎么办

Windows10的搜索功能是真的方便,这点用惯了Windows10的小伙伴应该都知道,不过它有个小问题,就是Windows10虽然会自动联网搜索,但默认使用微软自家的Bing搜索引擎和Edge...

面试秘籍:call、bind、apply的区别,面试官为什么总爱问这三位?

引言你有没有发现,每次JavaScript面试,面试官总爱问你call、bind和apply的区别?好像这三个方法成了通关密码,掌握了它们,就能顺利过关。其实不难理解,面试官问这些问题,不...

记住这8招,帮你掌握“追拍“摄影技法—摄影早自习第422日

杨海英同学提问:请问叶梓老师,我练习追拍时,总也不能把运动的人物拍清晰,速度一般掌握在1/40-1/60,请问您如何把追拍拍的清晰?这跟不同的运动形式有关系吗?请您给讲讲要点,谢谢您!摄影:Damia...

[Sony] 有点残酷的测试A7RII PK FS7

都是好机!手中利器!主要是最近天天研究fs5,想知道fs5与a7rii后期匹配问题,苦等朋友的fs5月底到货,于是先拿手里现有的fs7小测一下,十九八九也能看到fs5的影子,另外也了解一下fs5k标配...

AndroidStudio_Android使用OkHttp发起Http请求

这个okHttp的使用,其实网络上有很多的案例的,但是,如果以前没用过,copy别人的直接用的话,可以发现要么导包导不进来,要么,人家给的代码也不完整,这里自己整理一下.1.引入OkHttp的jar...

ESL-通过事件控制FreeSWITCH_es事务控制

通过事件提供的最底层控制机制,允许我们有效地利用工具箱,适时选择使用其中的单个工具。FreeSWITCH是一个核心交换与混合矩阵,它周围有几十个模块提供各种功能特性。我们完全控制了所有的即时信息,这些...

【调试】perf和火焰图_perf生成火焰图

简介perf是linux上的性能分析工具,perf可以对event进行统计得到event的发生次数,或者对event进行采样,得到每次event发生时的相关数据(cpu、进程id、运行栈等),利用这些...

文本检索控件也玩安卓?dtSearch Engine发布Android测试版

dtSearchEngineforLinux(原生64-bit/32-bitC++和JavaAPIs)和dtSearchEngineforWin&.NET(原生64-bi...

网站后台莫名增加N个管理员,记一次SQL注入攻击

网站没流量,但却经常被SQL注入光顾。最近,网站真的很奇怪,网站后台不光莫名多了很多“管理员”,所有的Wordpres插件还会被自动暂停,导致一些插件支持的页面,如WooCommerce无法正常访问、...

多元回归树分析Multivariate Regression Trees,MRT

多元回归树(MultivariateRegressionTrees,MRT)是单元回归树的拓展,是一种对一系列连续型变量递归划分成多个类群的聚类方法,是在决策树(decision-trees)基础...

JMETER性能测试_JMETER性能测试指标

jmeter为性能测试提供了一下特色:jmeter可以对测试静态资源(例如js、html等)以及动态资源(例如php、jsp、ajax等等)进行性能测试jmeter可以挖掘出系统最大能处...