{"id":478,"date":"2016-10-14T14:40:43","date_gmt":"2016-10-14T06:40:43","guid":{"rendered":"http:\/\/188.131.173.16\/?p=478"},"modified":"2016-10-14T14:40:43","modified_gmt":"2016-10-14T06:40:43","slug":"vba%e5%9c%a8word%e4%b8%ad%e7%9a%84%e5%ba%94%e7%94%a8","status":"publish","type":"post","link":"https:\/\/li-yang.cn\/?p=478","title":{"rendered":"VBA\u5728Word\u4e2d\u7684\u5e94\u7528"},"content":{"rendered":"<p>VBA\u5373Visual Basic for Applications,\u4f7fVB\u7684\u4e00\u79cd\u5b8f\u8bed\u8a00\u3002\u8fd9\u79cd\u8bed\u8a00\u5728Office\u529e\u516c\u8f6f\u4ef6\u4e2d\u5747\u53ef\u4f7f\u7528\u3002\u8fd9\u91cc\u4e3b\u8981\u5199\u5728Word\u64b0\u5199\u6587\u6863\u65f6\u5982\u4f55\u4f7f\u7528\u8fd9\u79cd\u8bed\u8a00\u63d0\u9ad8\u5de5\u4f5c\u6548\u7387\u3002<!--more--><br \/>\n<strong>1. \u6279\u91cf\u66ff\u6362\u6587\u6863\u4e2d\u7684\u5185\u5bb9\uff0c\u5982\u516c\u53f8\u540d\u79f0<\/strong><br \/>\n\u5728Word\u6587\u6863\u4e2d\u5148\u5c06\u9700\u8981\u66ff\u6362\u7684\u5185\u5bb9\u7528\u7edf\u4e00\u7684\u533a\u522b\u4e8e\u6b63\u5e38\u6587\u672c\u7684\u6807\u5fd7\u4ee3\u66ff\uff0c\u5982\u516c\u53f8\u540d\u79f0\u53ef\u4ee5\u5199\u4e3aGSMC\uff0c\u7136\u540e\u4f7f\u7528VBA\u4e2d\u7684InputBox\u8ba9\u7528\u6237\u4ece\u63d0\u793a\u6846\u4e2d\u8f93\u5165\u4fe1\u606f\uff0c\u5e76\u5c06\u4fe1\u606f\u7684\u503c\u4f20\u7ed9\u53d8\u91cf\u3002\u901a\u8fc7Selection\u51fd\u6570\u7684Find\u65b9\u6cd5\u53ef\u4ee5\u5b9e\u73b0\u6279\u91cf\u66ff\u6362\u3002<br \/>\n<strong>2. \u81ea\u52a8\u53e6\u5b58\u4e3a\uff0c\u5e76\u6309\u7167\u89c4\u5219\u8bbe\u7f6e\u6587\u4ef6\u540d<\/strong><br \/>\nChangeFileOpenDirectory \u51fd\u6570\u53ef\u4ee5\u6539\u53d8\u6587\u6863\u7684\u5f53\u524d\u76ee\u5f55\u3002\u5982ChangeFileOpenDirectory &#8220;C:UsersAdministratorDesktop&#8221;\u53ef\u4ee5\u5c06\u5f53\u524d\u76ee\u5f55\u8bbe\u7f6e\u5230\u684c\u9762\u3002\u7136\u540e\u53ef\u4ee5\u8c03\u7528Date\u51fd\u6570\u83b7\u53d6\u7cfb\u7edf\u65f6\u95f4\u7b49\u65b9\u6cd5\uff0c\u6309\u7167\u89c4\u5219\u8bbe\u7f6e\u6587\u4ef6\u540d\u3002ActiveDocument\u51fd\u6570SaveAs2\u65b9\u6cd5\u53ef\u4ee5\u5c06\u6587\u4ef6\u53e6\u5b58\u3002<\/p>\n<blockquote><p>\u4ee5\u4e0b\u662f\u5728\u5199\u6d4b\u8bd5\u62a5\u544a\u662f\u7528\u5230\u7684\u4e00\u6bb5VBA\u7a0b\u5e8f\uff0c\u53ef\u4ee5\u66f4\u7b80\u5355\u4fbf\u6377\u7684\u5b8c\u6210\u62a5\u544a\u7684\u64b0\u5199\u3002<br \/>\n<code><br \/>\n<span style=\"color:#999999;\">Attribute VB_Name = \"\u6a21\u57571\"<\/span><br \/>\n<span style=\"color:#999999;\"> Public Sub PentestReport()<\/span><br \/>\n<span style=\"color:#999999;\"> Dim Company As String<\/span><br \/>\n<span style=\"color:#999999;\"> Dim URL As String<\/span><br \/>\n<span style=\"color:#999999;\"> Dim AppName As String<\/span><br \/>\n<span style=\"color:#999999;\"> Dim BeginDate As String<\/span><br \/>\n<span style=\"color:#999999;\"> Dim EndDate As String<\/span><br \/>\n<span style=\"color:#999999;\"> NowDate = Format$(Now, \"Long Date\")<\/span><br \/>\n<span style=\"color:#999999;\"> Company = InputBox(\"\u8bf7\u8f93\u5165\u5ba2\u6237\u540d\u79f0\", \"\u5ba2\u6237\u4fe1\u606f\")<\/span><br \/>\n<span style=\"color:#999999;\"> AppName = InputBox(\"\u8bf7\u8f93\u5165\u7cfb\u7edf\u540d\u79f0\", \"\u7cfb\u7edf\u4fe1\u606f\")<\/span><br \/>\n<span style=\"color:#999999;\"> URL = InputBox(\"\u8bf7\u8f93\u5165\u7cfb\u7edfURL\", \"\u7cfb\u7edf\u4fe1\u606f\")<\/span><br \/>\n<span style=\"color:#999999;\"> BeginDate = InputBox(\"\u8bf7\u8f93\u5165\u6d4b\u8bd5\u5f00\u59cb\u65e5\u671f\", \"\u6d4b\u8bd5\u65e5\u671f\", NowDate)<\/span><br \/>\n<span style=\"color:#999999;\"> EndDate = InputBox(\"\u8bf7\u8f93\u5165\u6d4b\u8bd5\u7ed3\u675f\u65e5\u671f\", \"\u6d4b\u8bd5\u65e5\u671f\", NowDate)<\/span><\/code><br \/>\n<span style=\"color:#999999;\">&#8216;\u5ba2\u6237\u540d\u79f0\u66ff\u6362<\/span><br \/>\n<span style=\"color:#999999;\"> Selection.Find.ClearFormatting<\/span><br \/>\n<span style=\"color:#999999;\"> Selection.Find.Replacement.ClearFormatting<\/span><br \/>\n<span style=\"color:#999999;\"> With Selection.Find<\/span><br \/>\n<span style=\"color:#999999;\"> .Text = &#8220;KHMC&#8221;<\/span><br \/>\n<span style=\"color:#999999;\"> .Replacement.Text = Company<\/span><br \/>\n<span style=\"color:#999999;\"> .Forward = True<\/span><br \/>\n<span style=\"color:#999999;\"> .Wrap = wdFindContinue<\/span><br \/>\n<span style=\"color:#999999;\"> .Format = False<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchCase = True<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchWholeWord = False<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchByte = True<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchWildcards = False<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchSoundsLike = False<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchAllWordForms = False<\/span><br \/>\n<span style=\"color:#999999;\"> End With<\/span><br \/>\n<span style=\"color:#999999;\"> Selection.Find.Execute Replace:=wdReplaceAll<\/span><br \/>\n<span style=\"color:#999999;\">&#8216;\u7cfb\u7edfURL\u66ff\u6362<\/span><br \/>\n<span style=\"color:#999999;\"> Selection.Find.ClearFormatting<\/span><br \/>\n<span style=\"color:#999999;\"> Selection.Find.Replacement.ClearFormatting<\/span><br \/>\n<span style=\"color:#999999;\"> With Selection.Find<\/span><br \/>\n<span style=\"color:#999999;\"> .Text = &#8220;XTURL&#8221;<\/span><br \/>\n<span style=\"color:#999999;\"> .Replacement.Text = URL<\/span><br \/>\n<span style=\"color:#999999;\"> .Forward = True<\/span><br \/>\n<span style=\"color:#999999;\"> .Wrap = wdFindContinue<\/span><br \/>\n<span style=\"color:#999999;\"> .Format = False<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchCase = True<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchWholeWord = False<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchByte = True<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchWildcards = False<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchSoundsLike = False<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchAllWordForms = False<\/span><br \/>\n<span style=\"color:#999999;\"> End With<\/span><br \/>\n<span style=\"color:#999999;\"> Selection.Find.Execute Replace:=wdReplaceAll<\/span><br \/>\n<span style=\"color:#999999;\">&#8216;\u7cfb\u7edf\u540d\u79f0\u66ff\u6362<\/span><br \/>\n<span style=\"color:#999999;\"> Selection.Find.ClearFormatting<\/span><br \/>\n<span style=\"color:#999999;\"> Selection.Find.Replacement.ClearFormatting<\/span><br \/>\n<span style=\"color:#999999;\"> With Selection.Find<\/span><br \/>\n<span style=\"color:#999999;\"> .Text = &#8220;XTMC&#8221;<\/span><br \/>\n<span style=\"color:#999999;\"> .Replacement.Text = AppName<\/span><br \/>\n<span style=\"color:#999999;\"> .Forward = True<\/span><br \/>\n<span style=\"color:#999999;\"> .Wrap = wdFindContinue<\/span><br \/>\n<span style=\"color:#999999;\"> .Format = False<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchCase = True<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchWholeWord = False<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchByte = True<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchWildcards = False<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchSoundsLike = False<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchAllWordForms = False<\/span><br \/>\n<span style=\"color:#999999;\"> End With<\/span><br \/>\n<span style=\"color:#999999;\"> Selection.Find.Execute Replace:=wdReplaceAll<\/span><br \/>\n<span style=\"color:#999999;\">&#8216;\u65e5\u671f\u7684\u66ff\u6362<\/span><br \/>\n<span style=\"color:#999999;\"> If EndDate = BeginDate Then<\/span><br \/>\n<span style=\"color:#999999;\"> BeginDate = &#8220;&#8221;<\/span><br \/>\n<span style=\"color:#999999;\"> Selection.Find.ClearFormatting<\/span><br \/>\n<span style=\"color:#999999;\"> Selection.Find.Replacement.ClearFormatting<\/span><br \/>\n<span style=\"color:#999999;\"> With Selection.Find<\/span><br \/>\n<span style=\"color:#999999;\"> .Text = &#8220;KSRQ1&#8221;<\/span><br \/>\n<span style=\"color:#999999;\"> .Replacement.Text = EndDate<\/span><br \/>\n<span style=\"color:#999999;\"> .Forward = True<\/span><br \/>\n<span style=\"color:#999999;\"> .Wrap = wdFindContinue<\/span><br \/>\n<span style=\"color:#999999;\"> .Format = False<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchCase = True<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchWholeWord = False<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchByte = True<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchWildcards = False<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchSoundsLike = False<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchAllWordForms = False<\/span><br \/>\n<span style=\"color:#999999;\"> End With<\/span><br \/>\n<span style=\"color:#999999;\"> Selection.Find.Execute Replace:=wdReplaceAll<\/span><br \/>\n<span style=\"color:#999999;\"> Else<\/span><br \/>\n<span style=\"color:#999999;\"> BeginDate = BeginDate + &#8220;-&#8220;<\/span><br \/>\n<span style=\"color:#999999;\"> With Selection.Find<\/span><br \/>\n<span style=\"color:#999999;\"> .Text = &#8220;KSRQ1&#8221;<\/span><br \/>\n<span style=\"color:#999999;\"> .Replacement.Text = BeginDate<\/span><br \/>\n<span style=\"color:#999999;\"> .Forward = True<\/span><br \/>\n<span style=\"color:#999999;\"> .Wrap = wdFindContinue<\/span><br \/>\n<span style=\"color:#999999;\"> .Format = False<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchCase = True<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchWholeWord = False<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchByte = True<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchWildcards = False<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchSoundsLike = False<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchAllWordForms = False<\/span><br \/>\n<span style=\"color:#999999;\"> End With<\/span><br \/>\n<span style=\"color:#999999;\"> Selection.Find.Execute Replace:=wdReplaceAll<\/span><br \/>\n<span style=\"color:#999999;\"> End If<\/span><br \/>\n<span style=\"color:#999999;\"> Selection.Find.ClearFormatting<\/span><br \/>\n<span style=\"color:#999999;\"> Selection.Find.Replacement.ClearFormatting<\/span><br \/>\n<span style=\"color:#999999;\"> With Selection.Find<\/span><br \/>\n<span style=\"color:#999999;\"> .Text = &#8220;JSRQ&#8221;<\/span><br \/>\n<span style=\"color:#999999;\"> .Replacement.Text = EndDate<\/span><br \/>\n<span style=\"color:#999999;\"> .Forward = True<\/span><br \/>\n<span style=\"color:#999999;\"> .Wrap = wdFindContinue<\/span><br \/>\n<span style=\"color:#999999;\"> .Format = False<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchCase = True<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchWholeWord = False<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchByte = True<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchWildcards = False<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchSoundsLike = False<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchAllWordForms = False<\/span><br \/>\n<span style=\"color:#999999;\"> End With<\/span><br \/>\n<span style=\"color:#999999;\"> Selection.Find.Execute Replace:=wdReplaceAll<\/span><br \/>\n<span style=\"color:#999999;\"> Selection.Find.ClearFormatting<\/span><br \/>\n<span style=\"color:#999999;\"> Selection.Find.Replacement.ClearFormatting<\/span><br \/>\n<span style=\"color:#999999;\"> With Selection.Find<\/span><br \/>\n<span style=\"color:#999999;\"> .Text = &#8220;KSRQ&#8221;<\/span><br \/>\n<span style=\"color:#999999;\"> .Replacement.Text = BeginDate<\/span><br \/>\n<span style=\"color:#999999;\"> .Forward = True<\/span><br \/>\n<span style=\"color:#999999;\"> .Wrap = wdFindContinue<\/span><br \/>\n<span style=\"color:#999999;\"> .Format = False<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchCase = True<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchWholeWord = False<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchByte = True<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchWildcards = False<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchSoundsLike = False<\/span><br \/>\n<span style=\"color:#999999;\"> .MatchAllWordForms = False<\/span><br \/>\n<span style=\"color:#999999;\"> End With<\/span><br \/>\n<span style=\"color:#999999;\"> Selection.Find.Execute Replace:=wdReplaceAll<\/span><br \/>\n<span style=\"color:#999999;\">&#8216;\u66f4\u65b0\u6240\u6709\u57df<\/span><br \/>\n<span style=\"color:#999999;\"> Selection.WholeStory<\/span><br \/>\n<span style=\"color:#999999;\"> Selection.Fields.Update<\/span><br \/>\n<span style=\"color:#999999;\"> Selection.HomeKey Unit:=wdLine<\/span><br \/>\n<span style=\"color:#999999;\">&#8216;\u53e6\u5b58\u4e3a<\/span><br \/>\n<span style=\"color:#999999;\"> SaveDate = Format$(Now, &#8220;yyyymmdd&#8221;) + &#8220;.&#8221;<\/span><br \/>\n<span style=\"color:#999999;\"> ChangeFileOpenDirectory &#8220;C:UsersAdministratorDesktop&#8221;<\/span><br \/>\n<span style=\"color:#999999;\"> FileName = SaveDate + AppName + &#8220;\u5b89\u5168\u6e17\u900f\u6d4b\u8bd5\u62a5\u544aV1.0.docx&#8221;<\/span><br \/>\n<span style=\"color:#999999;\">ActiveDocument.SaveAs2 FileName:=FileName, FileFormat:= _<\/span><br \/>\n<span style=\"color:#999999;\"> wdFormatXMLDocument, LockComments:=False, Password:=&#8221;&#8221;, AddToRecentFiles _<\/span><br \/>\n<span style=\"color:#999999;\"> :=True, WritePassword:=&#8221;&#8221;, ReadOnlyRecommended:=False, EmbedTrueTypeFonts _<\/span><br \/>\n<span style=\"color:#999999;\"> :=False, SaveNativePictureFormat:=False, SaveFormsData:=False, _<\/span><br \/>\n<span style=\"color:#999999;\"> SaveAsAOCELetter:=False, CompatibilityMode:=15<\/span><br \/>\n<span style=\"color:#999999;\"> FinalPath = &#8220;\u5df2\u53e6\u5b58\u4e3a&#8221; + &#8220;C:UsersAdministratorDesktop&#8221; + FileName<\/span><br \/>\n<span style=\"color:#999999;\"> MsgBox FinalPath<\/span><\/p><\/blockquote>\n","protected":false},"excerpt":{"rendered":"<p>VBA\u5373Visual Basic for Appl [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[4],"tags":[],"class_list":["post-478","post","type-post","status-publish","format-standard","hentry","category-4"],"_links":{"self":[{"href":"https:\/\/li-yang.cn\/index.php?rest_route=\/wp\/v2\/posts\/478","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/li-yang.cn\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/li-yang.cn\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/li-yang.cn\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/li-yang.cn\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=478"}],"version-history":[{"count":0,"href":"https:\/\/li-yang.cn\/index.php?rest_route=\/wp\/v2\/posts\/478\/revisions"}],"wp:attachment":[{"href":"https:\/\/li-yang.cn\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=478"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/li-yang.cn\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=478"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/li-yang.cn\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=478"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}