Public Declare Function GetSaveFileName _
        Lib "comdlg32.dll" Alias "GetSaveFileNameA" _
        (pOpenfilename As OPENFILENAME) As LongPublic Type OPENFILENAME
    lStructSize As Long
    hwndOwner As Long
    hInstance As Long
    lpstrFilter As String
    lpstrCustomFilter As String
    nMaxCustFilter As Long
    nFilterIndex As Long
    lpstrFile As String
    nMaxFile As Long
    lpstrFileTitle As String
    nMaxFileTitle As Long
    lpstrInitialDir As String
    lpstrTitle As String
    flags As Long
    nFileOffset As Integer
    nFileExtension As Integer
    lpstrDefExt As String
    lCustData As Long
    lpfnHook As Long
    lpTemplateName As String
End TypePublic Const OFN_HIDEREADONLY = &H4 '隐藏只读打开
Public Const OFN_READONLY = &H1 '只读打开为选中
Public Const OFN_OVERWRITEPROMPT = &H2 '覆盖时提示
Public Const OFN_ALLOWMULTISELECT = &H200 '多个选中
Public Const OFN_EXPLORER = &H80000 '资源管理器Public Function ShowSave(MehWnd As Long, _
        FileSave As String, _
        Optional Title As String = "保存:", _
        Optional Filter As String = vbNullChar + vbNullChar, _
        Optional FilterIndex As Long = 0, _
        Optional StartDir As String = vbNullChar, _
        Optional flags As Long = OFN_HIDEREADONLY Or OFN_OVERWRITEPROMPT) As Long
    Dim SaveFN As OPENFILENAME
    Dim Rc As Long
    
    With SaveFN
        .hwndOwner = MehWnd
        .hInstance = App.hInstance
        .lpstrTitle = Title
        .lpstrFilter = Filter
        .nFilterIndex = FilterIndex
        .lpstrInitialDir = StartDir
        .lpstrFile = FileSave + String$(255, Chr$(0))
        .nMaxFile = Len(.lpstrFile)
        .lpstrFileTitle = .lpstrFile
        .nMaxFileTitle = 255
        .flags = flags
        .lStructSize = Len(SaveFN)
        
    End With
    
    Rc = GetSaveFileName(SaveFN)
    
    If Rc Then
        FileSave = Left$(SaveFN.lpstrFile, SaveFN.nMaxFile)
        ShowSave = True
        
    Else
        ShowSave = False
        
    End If
    
End Function