我有一个宏来查看单元格是否包含此字符串,如果包含此宏,则执行具有此设置名称标准的"save“命令。当我试图运行宏时,if语句似乎不起作用。当我一步一步地完成时,它会命中if语句,但它保存的是personal.xlsb而不是我正在处理的文件。在这里,我知道我的代码有问题
Dim FName As String
Dim FPath As String
Dim answer As Integer
If ActiveWorkbook.Sheets("Sheet1").Range("A1") = "String1" Then
FPath = "C:\String1"
FName = Sheets("Sheet1").Range("A1").Text
If Len(FPath & "\" & FName) = 0 Then
answer = MsgBox("Do you want to Save File As: " & FName & "?", vbYesNo + vbQuestion, "Microsoft Excel")
If answer = vbYes Then
ThisWorkbook.SaveAs Filename:=FPath & "\" & FName
End If
Else
ThisWorkbook.Save
End If
End If我最愿意接受的建议是检查文件是否包含字符串,如果是的话,验证它不存在,如果是的话,只保存而不是另存为。
发布于 2016-10-04 18:58:47
ThisWorkbook引用代码所在的工作簿。据推测,代码在Personal.xlsb中,这就是为什么它保存的是XLSB文件,而不是activeworkbook。
试一试:
Dim FName As String
Dim FPath As String
Dim fullName As String
Dim rng As Range
Dim s as String
s = "String1"
With ActiveWorkbook
Set rng = .Sheets("Sheet1").Range("A1")
If rng.Value = s Then
FPath = "C:\" & s
FName = rng.Text
fullName = FPath & "\" & FName
If Len(fullName) = 0 Then
If MsgBox("Do you want to Save File As: " & FName & "?", vbYesNo + vbQuestion, "Microsoft Excel") = vbYes Then
.SaveAs Filename:=fullName
End If
Else
.Save
End If
End If
End Withhttps://stackoverflow.com/questions/39859665
复制相似问题