首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >编辑为文件重命名VBA以修复运行时错误:找不到文件

编辑为文件重命名VBA以修复运行时错误:找不到文件
EN

Stack Overflow用户
提问于 2013-06-26 13:32:39
回答 3查看 4.9K关注 0票数 1

通过一些研究和尝试,我发现了这个基本的VBA,它可以帮助我重命名大量的文件附件。我已经重命名了几十个附件,但我遇到了运行时错误'53: File Not File‘。有没有办法修改VBA以跳过找不到的文件名?

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
Sub RenameFiles()
Const strPath = "C:\Documents and Settings\User\My Documents\FolderName\"
Dim r As Long
Dim n As Long
n = Cells(Rows.Count, 1).End(xlUp).Row
For r = 2 To n
Name strPath & Cells(r, 1) As strPath & Cells(r, 2)
Next r
End Sub
EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2013-06-26 15:25:58

使用以下语句禁用错误处理:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
On Error Resume Next

要再次启用错误处理,必须使用以下语句:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
On Error Goto 0

这是一个很好的做法,禁用错误处理只对你真正想跳过错误的语句。另一方面,启用和禁用错误处理可能会减慢代码的运行速度。在这种情况下,你可以把它放在循环的周围。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
On Error Resume Next
For r = 2 To n
  Name strPath & Cells(r, 1) As strPath & Cells(r, 2)
Next r
On Error Goto 0
票数 2
EN

Stack Overflow用户

发布于 2013-06-26 15:12:15

在您的子例程的顶部添加以下行:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
On Error Resume Next

这条语句完全按照它所说的做,它忽略了错误并继续下一行代码。

在使用此语句时,您需要使用注意,因为它不能修复错误。对于您当前的问题,这应该没问题,但在许多其他问题中,您需要处理错误而不是忽略它。

获取基础知识的一个很好的资源是Error Handling in VBA

如果您想了解有关Excel VBA的更多信息,brettdj对What is the best way to master VBA macros的回答是一个很好的起点。

要查看On Error Resume NextOn Error GoTo 0对错误的影响,请在VBA编辑器中逐步执行以下操作:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
Sub ExcelVBAErrorDemo()

    Dim forceError As Integer

    ' ignore errors
    On Error Resume Next
    ' cause an error
    forceError = 1 / 0

    ' the error was ignored, and the integer variable will
    ' display its default value
    MsgBox "Our forceError variable = " & forceError

    ' turn default error handling behavior back on
    On Error GoTo 0
    ' now we'll get a run-time error
    forceError = 1 / 0

End Sub
票数 1
EN

Stack Overflow用户

发布于 2013-06-26 15:42:26

(在我看来)比On Error Resume Next更好的是检查特定的/预期的错误并适当地处理它们。在这种情况下,您可以检查文件名是否有效,如果无效,则跳过Name分配。

使用Dir()函数检查它是否是有效的文件名:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
Sub RenameFiles()
Const strPath = "C:\Documents and Settings\User\My Documents\FolderName\"
Dim sFile as String
Dim r As Long
Dim n As Long
n = Cells(Rows.Count, 1).End(xlUp).Row
For r = 2 To n
    sFile = strPath & Cells(r,1)
    If Not Dir(sFile) = vbNullString Then 
        Name sFile As strPath & Cells(r, 2)
    End If
Next r
End Sub
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/17321504

复制
相关文章
java找不到jdk文件_java运行时系统找不到指定的文件
学习jni的时候,javac Helloworld.java 生成 Helloworld.class文件以后,调用javah Helloworld提示找不到类文件
全栈程序员站长
2022/11/08
2.7K0
VBA: 批量重命名文件夹和文件名称
文章背景: 在工作中,有时需要将一些文件名称修改成特定的名称,如果文件比较多的话,手动修改费时费力,下面通过VBA代码实现批量操作。
Exploring
2022/12/18
9.5K2
VBA:  批量重命名文件夹和文件名称
使用VBA重命名文件:5个代码示例
注意到Name命令需要文件路径和文件名吗?因此,该命令不仅可以重命名文件,还可以移动文件。例如,下面的代码将文件从D:\完美Excel\移动到D:\完美Excel\我的文章\,但文件名保持不变。
fanjy
2022/11/16
2.4K0
使用VBA重命名文件:5个代码示例
pycharm重命名文件名后运行不了_重命名找不到该项目
4、这个时候,我们再运行py文件,就会出现‘系统找不到指定的文件’,运行不了py
全栈程序员站长
2022/09/27
2.1K1
pycharm重命名文件名后运行不了_重命名找不到该项目
linux重命名文件名_linux 文件重命名
https://blog.csdn.net/weixin_33724570/article/details/91909917
全栈程序员站长
2022/09/30
4.1K0
linux重命名文件名_linux 文件重命名
java删除文件,重命名文件
在做项目时,遇到需要对文件做一些删除重命名等操作。基于java语言,保存代码段如下。
全栈程序员站长
2022/08/12
1.8K0
VBA实战技巧10: 复制文件到指定的文件夹并重命名
在工作表的列A中放置着一系列带有完整路径的文件名列表,想要将这些文件移至指定的文件夹并使用列B中相应的名称对其重命名,如下图1所示。
fanjy
2020/12/18
8.5K0
VBA实战技巧10: 复制文件到指定的文件夹并重命名
linux批量文件重命名命令_shell重命名文件指令
hello_10_2016-03-17.log hello_4_2016-03-17.log hello_8_2016-03-17.log
全栈程序员站长
2022/10/02
10.7K0
删除,重命名文件
重命名文件----rename #define _CRT_SECURE_NO_WARNINGS #include<stdio.h> //修改文件名 void REname(char *arr) { int ret=rename("你好世界.txt", arr); if (ret == 0) { printf("修改成功"); } else { printf("修改失败"); } } void test01() { char buf[] = "你好,世界.txt"; REname(b
大忽悠爱学习
2021/03/02
1.7K0
删除,重命名文件
python3批量为文件重命名
为什么使用python批量重命名而没有使用shell,python对文字的处理更灵活,对于文件名中的空格不会出现报错。
py3study
2020/01/06
5820
linux中文件重命名_如何在Linux中重命名文件?
This tutorial will walk you through the simple steps to rename a file in Linux.
全栈程序员站长
2022/09/30
8.3K0
linux重命名文件和文件夹的区别_文件夹如何重命名
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
全栈程序员站长
2022/11/16
4.9K0
linux 重命名 文件夹_如何给文件批量重命名
上面的例子中,子模式 \d{4} 会捕捉4个连续的数字,捕捉的四个数字匹配模式对应 $1, 将会用于新的文件名。
全栈程序员站长
2022/09/30
7K0
linux 重命名 文件夹_如何给文件批量重命名
文件批量重命名
# 把当前文件夹的所有文件重命名为 WF .... # 把这个路径下的所有文件先查找到 -- 遍历所有文件 :有一个新的名字WF .. rename(旧,新) import os file_path = os.getcwd() list1 = os.listdir(file_path) print(list1) # 当前目录每个名字前面加'WF ' for name in list1: new_name = 'WF ' + name os.rename(name, new_na
汪凡
2018/05/29
1.5K0
EditRename文件重命名工具
一款文件重命名工具。通过在文本编辑器中直接编辑多个文件的文件名来重命名文件,非常灵活,堪比一些强大的重命名工具,但更加易用。
季春二九
2023/03/24
1.1K0
EditRename文件重命名工具
php案例 重命名文件
作者:陈业贵 华为云享专家 51cto(专家博主 明日之星 TOP红人) 阿里云专家博主 文章目录 代码 index.php 效果: 之前的 之后的 代码 index.php <?php //重命
贵哥的编程之路
2022/09/29
1.2K0
php案例 重命名文件
修复 GitLab 的 CI Runner 提示找不到 pwsh 执行文件
本文告诉大家如何修复使用 GitLab 的 Runner 做 CI 时提示 “pwsh”: executable file not found in %PATH% 错误
林德熙
2023/04/07
9620
linux 重命名文件和文件夹
其实在文本模式中要重命名文件或目录的话也是很简单的,我们只需要使用mv命令就可以了,比如说我们要将一个名为abc的文件重命名为1234就可以这样来写:mv abc 1234,但是要注意的是,如果当前目录下也有个1234的文件的话,我们的这个文件是会将它覆盖的
周小董
2019/03/25
4.7K0
VBA 批量重命名
If ActiveSheet .Range("c2") = "" Then
办公魔盒
2019/07/22
1.2K0
VBA 批量重命名
linux 文件重命名的命令是什么_linux移动文件并重命名
大家好,又见面了,我是你们的朋友全栈君。 就目前所知道的知识,有两种方法。 一、mv
全栈程序员站长
2022/09/30
5.6K0

相似问题

需要修复Applescript错误,以确定重命名文件的存在

11

用mercuial修复文件重命名错误

11

尝试重命名文件以删除连字符,找不到文件时出现错误

119

Python重命名错误“找不到文件”错误

16

VBA -重命名文件

13
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文