一般问题:
如何将“Microsoft Office中的’录制’创建的VBA宏中的功能”转换为可以在.vbs文件中的 Windows可执行VBScripts?

具体问题:
如何批量创建Word文档的缩略图以便在Windows资源管理器中查看?

替代问题:
在哪里可以找到有关使用VBS操作MS Word文档的文档?

我的最终目标是批量创建MS Word文档缩略图的过程.

我人性化的方法是:

>打开一个Word文档
>按’另存为’
>勾选’保存缩略图’
>保存和替换

我发现from a small website VBS,以.vbs文件的形式,可以操作Word文档.可以通过在Windows资源管理器中双击.vbs文件来执行的示例:

'in a file called "something.vbs"
Set objWord = CreateObject("Word.Application")

objWord.Visible = True
Set objDoc = objWord.Documents.Add()
Set objSelection = objWord.Selection

objSelection.Font.Name = "Arial"
objSelection.Font.Size = "18"
objSelection.TypeText "Network Adapter Report"
objSelection.TypeParagraph()

objSelection.Font.Size = "14"
objSelection.TypeText "" & Date()
objSelection.TypeParagraph()

我还发现通过’录制宏’,我可以得到一些VBA代码,用于保存带有缩略图的文档.这是我记录的一个宏:

Sub save_with_thumbnail()
'
' save_with_thumbnail Macro
'
'
    ChangeFileOpenDirectory _
        "E:\"
    ActiveDocument.SaveAs2 FileName:="as90520.doc",FileFormat:= _
        wdFormatDocument,LockComments:=False,Password:="",AddToRecentFiles:= _
        True,WritePassword:="",ReadOnlyRecommended:=False,EmbedTrueTypeFonts:= _
        False,SaveNativePictureFormat:=False,SaveFormsData:=False,_
        SaveAsAOCELetter:=False,CompatibilityMode:=0
End Sub

这两种方法中的每一种都解决了我的部分问题,但我无法将它们整合在一起.因此,我问是否有人 –

>可以通过将VBA宏转换为Windows可执行脚本来帮助集成/组合/无论两种方法,或者
>可以提供有关如何在Windows资源管理器中批量创建MS Word文档缩略图的建议,或者
>知道某些参考文档的存在,它提供了有关此CreateObject.(“Word.Application”)和.Documents.Add()以及.Selection和..SaveAs的更多信息 – 无论如何,各种各样.

希望我已经把这个问题措辞得很好了.提前感谢您的帮助.

最初的起点是不同的.在VBA中,您有一组内置对象,例如Application,它引用当前运行的Word应用程序.在VBS中,您必须创建一个新的Application对象并将其保存在变量中:
Dim wdApp
Set wdApp = CreateObject("Word.Application")

或获取对已运行的Word应用程序的引用:

Set wdApp = Getobject(,"Word.Application")

完成后,它们之间的代码几乎可以互换:

Dim wdDoc
Set wdDoc = wdApp.Open("path\to\document.docx")

请记住,在VBA变量中可以有一个类型.而不是以前的变量声明(Dim wdDoc),在VBA中你可以看到:

Dim wdDoc As Word.Document
'alternatively:
'Dim wdDoc As Document

此外,VBA通常可以访问枚举常量,例如wdFormatDocument.在VBScript中,您可以手动定义常量:

Const wdFormatDocument = 0

或者直接使用常量的值:

wdApp.ActiveDocument.SaveAs2 FileName:="as90520.doc",FileFormat:= 0

可以在here找到Word对象模型的参考.

就您的具体问题而言,ActiveDocument是Application对象的属性(参见here).所以在VBS中,相应的代码可能如下所示:

Dim wdApp
Set wdApp = CreateObject("Word.Application")

'When you open Word from the Start menu,it automatically adds a blank document for you
'When manipulating Word in a program,we need to do this by hand
'Generally we would store this in a variable,but we don't need to store it in order
'to use the ActiveDocument property; it just has to exist
wdApp.Documents.Add

'copied and pasted from before
wdApp.ActiveDocument.SaveAs2 FileName:="as90520.doc",FileFormat:= _
    wdFormatDocument,AddToRecentFiles:= _
    True,EmbedTrueTypeFonts:= _
    False,_
    SaveAsAOCELetter:=False,CompatibilityMode:=0

vbscript – 在Windows上使用VBS处理MS Word的更多相关文章

  1. Xcode不显示任务控制视图中所有窗口的标题(4个手指向下滑动)

    MacMissionControl是一个方便的功能,它允许我们导航一个应用程序的不同窗口.大多数应用程序会在每个窗口缩略图下方显示窗口标题,因此很容易找到您想要带到前面的窗口.但是,如果我在Xcode4.2.1中打开一些项目并进行4指滑动,我在窗口缩略图下面看不到任何“标题”或“项目名称”.这很烦人,因为有时窗口预览缩略图并不总是足以识别内部的内容.是否有任何需要更改才能显示的设置?或者它还不可能?

  2. 在iOS中处理大图片

    我发现有一个BitmapFactory类,它有一个inSampleSize选项,可以在Android平台中对照片进行缩减.在iOS上怎么做?

  3. 如何在iOS 7中的UITextField中添加缩略图UIImage?

    本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请发送邮件至dio@foxmail.com举报,一经查实,本站将立刻删除。

  4. iOS – 如何在没有游戏的情况下从视频获取缩略图?

    我正在尝试从视频中获取缩略图并在我的tableview中显示它.这是我的代码:但是图像总是回归黑色.怎么了?

  5. ios – 如何将UIImage保存到文档目录?

    如何将缩略图与其来自的视频一起写入我的文档目录?到目前为止,这是我的代码:解决方法就这么简单:一个建议:如果可以按照苹果的指南再次下载图像,则将图像保存到库/缓存中.

  6. 在Swift中,使用SDWebImage做缓存后获取缩略图的大小

    0//不等于1,执行下一个循环ifcount![0],options:[],progress:nil,completed:{->Voidin//图片缓存完成,但是图片不一定有imageifimage!=nil{//将image转成二进制数据letdata=UIImagePNGRepresentationdataLenth+=data!.length}//dispath_group_leave要放到闭包的最后,才能够正确的测试出。dispatch_group_leave})}//调度组回到主队列dispat

  7. swift – generateCGImagesAsynchronouslyForTimes有时不会生成完整的缩略图

    我正在使用一个使用AVAssetImageGenerator.generateCGImagesAsynchronouslyForTimes的OSX应用程序,它通常工作正常.然而,一段时间后,我回来的缩略图只包含前几行像素,其余的是绿色,有时图像将是不同的绿色.很难跟踪,因为它不会一直发生,但是当大约一半的缩略图受到影响时.这是我期望看到的形象:但经常发生这种情况:以下是我用来生成缩略图的代码:这就

  8. android – MediaStore:获取图像数据,缩略图和文件夹

    我有两个清单.我们称它们为AlbumsList和PicturesList.>第一个显示相册封面,它的名称和图片数量.>第二个显示所选专辑中包含的所有图像.我已经使用File类完成了它,但它工作得太慢,当我只需要来自图库的那些时,它会在设备上找到所有图像.我读过有关MediaStore内容提供商但从未使用过它.所以我有两个问题:>如何使用MediaStore类找到“相册”,缩略图和图片中的图片数量?>如何使用MediaStore类获取特定文件夹中所有图像的文件路径和缩略图?

  9. android – 从图像中删除或更新exif缩略图

    无论如何从图像中删除exif缩略图?我在我的应用程序中裁剪图像并使用sanselan库复制所有exif数据无损.然后,我相应地更新宽度/高度/旋转.我找不到任何方法来更新exif缩略图或删除它,任何想法如何做到这一点?

  10. 如何从Android 4.0及更高版本的远程URL获取视频缩略图?

    实际上,我想显示视频网址中的视频缩略图并在ImageView中显示,然后点击ImageView,VideoView会在另一个活动中显示视频.所以最终我的问题是,我无法从URL获取视频缩略图.我已经尝试了很多,但无法获得任何适用于我的解决方案,有解决方案只能从SD卡视频获取缩略图和远程URL,我找到了一些解决方案,但它不起作用.Below是我试过的.有人能告诉我如何显示URL中的视频缩略图吗?

随机推荐

  1. static – 在页面之间共享数据的最佳实践

    我想知道在UWP的页面之间发送像’selectedItem’等变量的最佳做法是什么?创建一个每个页面都知道的静态全局变量类是一个好主意吗?

  2. .net – 为Windows窗体控件提供百分比宽度/高度

    WindowsForm开发的新手,但在Web开发方面经验丰富.有没有办法为Windows窗体控件指定百分比宽度/高度,以便在用户调整窗口大小时扩展/缩小?当窗口调整大小时,可以编写代码来改变控件的宽度/高度,但我希望有更好的方法,比如在HTML/CSS中.在那儿?

  3. 使用Windows Azure查询表存储数据

    我需要使用特定帐户吗?>将应用程序部署到Azure服务后,如何查询数据?GoogleAppEngine有一个数据查看器/查询工具,Azure有类似的东西吗?>您可以看到的sqlExpressintance仅在开发结构中,并且一旦您表示没有等效,所以请小心使用它.>您可以尝试使用Linqpad查询表格.看看JamieThomson的thispost.

  4. windows – SetupDiGetClassDevs是否与文档中的设备实例ID一起使用?

    有没有更好的方法可以使用DBT_DEVICEARRIVAL事件中的数据获取设备的更多信息?您似乎必须指定DIGCF_ALLCLASSES标志以查找与给定设备实例ID匹配的所有类,或者指定ClassGuid并使用DIGCF_DEFAULT标志.这对我有用:带输出:

  5. Windows Live ID是OpenID提供商吗?

    不,WindowsLiveID不是OpenID提供商.他们使用专有协议.自从他们的“测试版”期结束以来,他们从未宣布计划继续它.

  6. 如果我在代码中进行了更改,是否需要重新安装Windows服务?

    我写了一个Windows服务并安装它.现在我对代码进行了一些更改并重新构建了解决方案.我还应该重新安装服务吗?不,只需停止它,替换文件,然后重新启动它.

  7. 带有双引号的字符串回显使用Windows批处理输出文件

    我正在尝试使用Windows批处理文件重写配置文件.我循环遍历文件的行并查找我想要用指定的新行替换的行.我有一个’函数’将行写入文件问题是%Text%是一个嵌入双引号的字符串.然后失败了.可能还有其他角色也会导致失败.如何才能使用配置文件中的所有文本?尝试将所有“在文本中替换为^”.^是转义字符,因此“将被视为常规字符你可以尝试以下方法:其他可能导致错误的字符是:

  8. .net – 将控制台应用程序转换为服务?

    我正在寻找不同的优势/劣势,将我们长期使用的控制台应用程序转换为Windows服务.我们为ActiveMQ使用了一个叫做java服务包装器的东西,我相信人们告诉我你可以用它包装任何东西.这并不是说你应该用它包装任何东西;我们遇到了这个问题.控制台应用程序是一个.NET控制台应用程序,默认情况下会将大量信息记录到控制台,尽管这是可配置的.任何推荐?我们应该在VisualStudio中将其重建为服务吗?我使用“-install”/“-uninstall”开关执行此操作.例如,seehere.

  9. windows – 捕获外部程序的STDOUT和STDERR *同时*它正在执行(Ruby)

    哦,我在Windows上:-(实际上,它比我想象的要简单,这看起来很完美:…是的,它适用于Windows!

  10. windows – 当我试图批量打印变量时,为什么我得到“Echo is on”

    我想要执行一个简单的批处理文件脚本:当我在XP中运行时,它给了我预期的输出,但是当我在Vista或Windows7中运行它时,我在尝试打印值时得到“EchoisOn”.以下是程序的输出:摆脱集合表达式中的空格.等号(=)的两侧可以并且应该没有空格BTW:我通常在@echo关闭的情况下启动所有批处理文件,并以@echo结束它们,所以我可以避免将代码与批处理文件的输出混合.它只是使您的批处理文件输出更好,更清洁.

返回
顶部