ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
楼主: jiminyanyan

[已解决] 请教问题将文件及子文件夹下所有的word 文件改名

[复制链接]

TA的精华主题

TA的得分主题

 楼主| 发表于 2014-5-19 21:47 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
zhaogang1960 发表于 2014-5-19 12:56
请测试附件

赵老师,我想把文件夹及子文件夹中的word 的内容由 蓝天 改为白云,怎么不成功呢。。。。 批量替换问题V1.2.rar (36.38 KB, 下载次数: 24)

TA的精华主题

TA的得分主题

发表于 2014-5-19 22:06 | 显示全部楼层
jiminyanyan 发表于 2014-5-19 21:47
赵老师,我想把文件夹及子文件夹中的word 的内容由 蓝天 改为白云,怎么不成功呢。。。。
  1. Private Sub 确定_Click()
  2.      On Error Resume Next
  3.     Dim Fso As Object, Folder As Object, arrf$(), mf&
  4.     Dim str1 As String
  5.     Dim str2 As String
  6.     Set Fso = CreateObject("Scripting.FileSystemObject")
  7.     str1 = 新名称.Text
  8.     str2 = 替换名称.Text
  9.     'Set Folder = Fso.GetFolder(路径)
  10.     'Call GetFiles(Folder, str1, str2)
  11.     Set Folder = Fso.GetFolder(路径)
  12.     Call 替换(Folder, arrf, mf)
  13.     With CreateObject("Word.Application")
  14.         .Visible = False
  15.         For i = 1 To mf
  16.             .Documents.Open arrf(i)
  17.             .Selection.HomeKey Unit:=6
  18.             Do While .Selection.Find.Execute(str1)
  19.                 .Selection.Text = str2 '替换字符串
  20.                 .Selection.HomeKey Unit:=6
  21.             Loop
  22.             .Documents.Close True
  23.         Next
  24.         .Quit
  25.     End With
  26.     MsgBox "更改完毕!"
  27.     Set Folder = Nothing
  28.     Set Fso = Nothing
  29.    
  30. End Sub
复制代码
  1. Sub 替换(ByVal Folder As Object, arr$(), m&)
  2.     Dim SubFolder As Object
  3.     Dim file As Object
  4.     For Each file In Folder.Files
  5.         If file.Name Like "*.doc" Then
  6.             m = m + 1
  7.             ReDim Preserve arr(1 To m)
  8.             arr(m) = file
  9.         End If
  10.     Next
  11.     For Each SubFolder In Folder.SubFolders
  12.         Call 替换(SubFolder, arr, m)
  13.     Next
  14.     Set SubFolder = Nothing
  15. End Sub
复制代码

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2014-5-19 22:12 | 显示全部楼层
CreateObject("Word.Application")——打开Word不要放在子程序中,该子程序会调用多次,Word也就会重复打开
请测试附件
批量替换问题V1.2.rar (35.4 KB, 下载次数: 329)

TA的精华主题

TA的得分主题

发表于 2014-5-20 10:20 | 显示全部楼层
jiminyanyan 发表于 2014-5-19 21:05
批量替换问题V1.1

不错,提点建议,如果按以下修改,会更具有通用性。
18.png

……

TA的精华主题

TA的得分主题

 楼主| 发表于 2014-5-20 17:43 | 显示全部楼层
yf_home 发表于 2014-5-20 10:20
不错,提点建议,如果按以下修改,会更具有通用性。

关键字   和  序列号是什么意思,没看懂。。。。

TA的精华主题

TA的得分主题

发表于 2014-5-20 19:06 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
jiminyanyan 发表于 2014-5-20 17:43
关键字   和  序列号是什么意思,没看懂。。。。

关键字:比如, AA
序列号,比如:01,则命名规则为:AA01/AA02/AA03
序列号,比如:001,则命名规则为:AA001/AA002/AA003


.

TA的精华主题

TA的得分主题

发表于 2014-5-20 22:29 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
好,方便,期待更完善版本

TA的精华主题

TA的得分主题

发表于 2016-12-27 11:46 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2017-8-17 18:24 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2017-8-17 20:39 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
谢谢   分享
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-11-23 18:27 , Processed in 0.035187 second(s), 7 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表