Vba 从功能区运行宏时出错

Vba 从功能区运行宏时出错,vba,ms-word,Vba,Ms Word,我正在使用Microsoft Word 2010。我使用VBA编辑器编写了一段代码,用于保存我编辑的文档。基本上,它打开“另存为文件”对话框,并根据由文档中的某些文本和用户通过输入框输入的内容定义的字符串输入名称。 当我单击view macrocomands选项卡并从那里执行macrocomands时,我可以成功地运行它,但是如果我在功能区上放置快捷方式,文件会立即保存在C:\Users\Username\Documents中,与文档的第一行一起 Sub SaveAs() 'Preia numa

我正在使用Microsoft Word 2010。我使用VBA编辑器编写了一段代码,用于保存我编辑的文档。基本上,它打开“另存为文件”对话框,并根据由文档中的某些文本和用户通过输入框输入的内容定义的字符串输入名称。 当我单击view macrocomands选项卡并从那里执行macrocomands时,我可以成功地运行它,但是如果我在功能区上放置快捷方式,文件会立即保存在C:\Users\Username\Documents中,与文档的第一行一起

Sub SaveAs()
'Preia numarul dosarului in numele fisierului

Dim oRng As Range
Dim Nrdosar As String
Dim sTags As String
Set oRng = ActiveDocument.Range
With oRng.Find
.ClearFormatting
.Execute FindText:="Dosar nr. ", Forward:=True, _
Format:=False, Wrap:=wdFindStop
End With
oRng.Collapse 0
Nrdosar = oRng.Paragraphs(1).Range.Text
Nrdosar = Replace(Nrdosar, "Dosar nr. ", "")
Nrdosar = Replace(Nrdosar, "DOSAR NR. ", "")
Nrdosar = Replace(Nrdosar, "/4/", "-")
Nrdosar = Replace(Nrdosar, "/", "-")
Nrdosar = Replace(Nrdosar, "*", "")
Nrdosar = Replace(Nrdosar, Chr(13), "")
MsgBox Nrdosar
sTags = InputBox("Introduceti cuvinte cheie separate de virgula")
With Dialogs(wdDialogFileSaveAs)
    .Name = Nrdosar & " " & sTags & ".docx"
    .Show
    End With
End Sub
我已导出功能区快捷方式以尝试了解问题

<mso:cmd app="Word" dt="1" />
<mso:customUI xmlns:x1="http://schemas.microsoft.com/office/2009/07/customui/macro" xmlns:mso="http://schemas.microsoft.com/office/2009/07/customui"><mso:ribbon>
<mso:qat><mso:sharedControls>
<mso:control idQ="mso:FileNewDefault" visible="false"/><mso:control idQ="mso:FileOpen" visible="false"/>
<mso:control idQ="mso:FileSendAsAttachment" visible="false" insertBeforeQ="mso:FileSave"/>
<mso:control idQ="mso:FilePrintQuick" visible="false" insertBeforeQ="mso:FileSave"/>
<mso:control idQ="mso:PrintPreviewAndPrint" visible="false" insertBeforeQ="mso:FileSave"/>
<mso:control idQ="mso:SpellingAndGrammar" visible="false" insertBeforeQ="mso:FileSave"/>
<mso:control idQ="mso:TableDrawTable" visible="false" insertBeforeQ="mso:FileSave"/>
<mso:control idQ="mso:FileOpenRecentFile" visible="false" insertBeforeQ="mso:FileSave"/>
<mso:control idQ="mso:Undo" visible="true" insertBeforeQ="mso:FileSave"/><mso:control idQ="mso:RedoOrRepeat" visible="true" InsertBeforeQ="mso:FileSave"/>
<mso:control idQ="mso:FileSave" visible="true"/>
<mso:button idQ="x1:SaveAs_1" visible="true" label="Normal.NewMacros.SaveAs" imageMso="ListMacros" onAction="SaveAs"/>
</mso:sharedControls></mso:qat>
<mso:tabs>
<mso:tab idQ="mso:TabHome">
<mso:group id="mso_c1.-D823CC6" label="Auto" autoScale="true">
<mso:gallery idQ="mso:AutoTextGallery" showInRibbon="false" visible="true"/>
<mso:control idQ="mso:TableColumnsDelete" visible="true"/>
<mso:control idQ="mso:TableRowsDelete" visible="true"/>
<mso:button idQ="x1:SaveAs_0_102AE36C" label="Normal.NewMacros.SaveAs" imageMso="ListMacros" onAction="SaveAs" visible="true"/>
</mso:group>
</mso:tab><mso:tab id="mso_c1.5F8A243" label="FilÄ nouÄ">
<mso:group id="mso_c2.5F8A243" label="Grup nou" autoScale="true">
<mso:control idQ="mso:DateAndTimeInsert" visible="true"/>
</mso:group>
</mso:tab>
</mso:tabs>
</mso:ribbon>
</mso:customUI>

我无法想象为什么从View Macrocomands(查看Macrocomands)选项卡运行macrocomand与我在功能区中放置的快捷方式相比结果会有所不同

我相信VBA代码本身没有问题,并且存在某种缺陷。 我希望能够使用快捷方式运行VBA代码。
谢谢大家!

问题或bug出现在宏的名称中。我已将第一行更改为:

子SaveAs()

子存储文档()


我仍然不理解这种行为,但我想分享解决方法。

SaveAs
是Word中的内置命令(如File/Save-as)。因此,通过传递实际宏并执行Word的内置命令来发送命令以运行具有此名称的宏

为宏指定不同的名称(非保留名称)应该可以解决此问题