找回密码
 注册
搜索
[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
查看: 19975|回复: 3

[问题求助] VBS如何自动压缩doc、PPT文件中的图片?

[复制链接]
发表于 2012-12-3 09:26:16 | 显示全部楼层 |阅读模式
如上图所示,如何才能让VB做到相同的功能?
最好能自动查找指定目录下的所有doc和ppt文件并对其进行操作。
因为学校共享资源里的文件太多了,手动太慢,望高手解救。
发表于 2012-12-3 17:45:11 | 显示全部楼层
查找文件,用WSH.SendKeys模拟键盘操作
发表于 2012-12-3 18:17:36 | 显示全部楼层
找了一下网上的帖子,发现sendkeys不给力,只能弹出来自己一个个点了,还是节省了点工作,你可以看看相关的东西
  1. 'http://social.msdn.microsoft.com/Forums/en-US/isvvba/thread/4fbbd7e1-7ff1-4c97-a53b-eeef490b5e5c

  2. docsfolder = "C:\Users\Administrator\Desktop\docs"

  3. Set fso = CreateObject("Scripting.FileSystemObject")
  4. Set word = CreateObject("Word.Application")
  5.   word.Visible = True
  6. FindDocs docsfolder
  7. word.Quit

  8. Sub OpenOneDoc(sExactPath)
  9.   With word
  10.     .Documents.Open sExactPath, False, False
  11.     .Application.CommandBars.FindControl(1, 6382).Execute
  12.     ' wdDoNotSaveChanges = 0, wdPromptToSaveChanges = -2, wdSaveChanges = -1
  13.     .ActiveDocument.Close -1
  14.   End With
  15. End Sub

  16. Sub FindDocs(folderspec)  
  17.   Dim f, f1, fc, s
  18.   If Not fso.FolderExists(folderspec) Then
  19.     MsgBox "文件夹不存在"  
  20.     WScript.Quit
  21.   else  
  22.     Set f = fso.GetFolder(folderspec)
  23.     Set fc = f.files
  24.     For Each f1 in fc
  25.       If LCase(Right(f1.Path, 4)) = ".doc" Or LCase(Right(f1.Path, 5)) = ".docx" Then
  26.         OpenOneDoc f1.Path
  27.       End If
  28.     Next
  29.     Set ff=f.SubFolders  
  30.     For Each f2 in ff  
  31.       FindDocs f2.Path
  32.     Next
  33.   End If
  34. End Sub
复制代码
 楼主| 发表于 2012-12-4 15:14:29 | 显示全部楼层
先谢,再等看看有没有更好用的!顶起来
您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|手机版|小黑屋|批处理之家 ( 渝ICP备10000708号 )

GMT+8, 2026-3-17 01:12 , Processed in 0.017889 second(s), 7 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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