VBA文件对话框的应用(VBA打开文件、VBA选择文件、VBA选择文件夹) (转http://justsee.iteye.com/blog/1468664)

Coordinator
Jan 16, 2013 at 3:28 PM

 

    博客分类:
  • vba

VBA中经常要用到文件对话框来进行打开文件、选择文件或选择文件夹的操作。
用Microsoft Office提供的文件对话框比较方便。
用法如下
Application.FileDialog(fileDialogType)
fileDialogType MsoFileDialogType 类型,必需。文件对话框的类型

  MsoFileDialogType 可为以下 MsoFileDialogType 常量之一。
    msoFileDialogFilePicker 允许用户选择文件。
    msoFileDialogFolderPicker 允许用户选择一个文件夹。
    msoFileDialogOpen 允许用户打开文件。用Excel打开。
    msoFileDialogSaveAs 允许用户保存一个文件。

分别举例如下:

 

1、msoFileDialogFilePicker
1)选择单个文件

 

Java代码 复制代码 收藏代码
  1. Sub SelectFile()
  2. '选择单一文件
  3. With Application.FileDialog(msoFileDialogFilePicker)
  4. .AllowMultiSelect = False '单选择
  5. .Filters.Clear '清除文件过滤器
  6. .Filters.Add "Excel Files", "*.xls;*.xlw"
  7. .Filters.Add "All Files", "*.*" '设置两个文件过滤器
  8. If .Show = -1 Then 'FileDialog 对象的 Show 方法显示对话框,并且返回 -1(如果您按 OK)和 0(如果您按 Cancel)。
  9. MsgBox "您选择的文件是:" & .SelectedItems(1), vbOKOnly + vbInformation, "智能Excel"
  10. End If
  11. End With
  12. End Sub
Sub SelectFile()
    '选择单一文件
    With Application.FileDialog(msoFileDialogFilePicker)
        .AllowMultiSelect = False   '单选择
        .Filters.Clear   '清除文件过滤器
        .Filters.Add "Excel Files", "*.xls;*.xlw"
        .Filters.Add "All Files", "*.*"          '设置两个文件过滤器
        If .Show = -1 Then    'FileDialog 对象的 Show 方法显示对话框,并且返回 -1(如果您按 OK)和 0(如果您按 Cancel)。
            MsgBox "您选择的文件是:" & .SelectedItems(1), vbOKOnly + vbInformation, "智能Excel"
        End If
    End With
End Sub

 

2)选择多个文件

 

Java代码 复制代码 收藏代码
  1. Sub SelectFile()
  2. '选择多个文件
  3. Dim l As Long
  4. With Application.FileDialog(msoFileDialogFilePicker)
  5. .AllowMultiSelect = True '单选择
  6. .Filters.Clear '清除文件过滤器
  7. .Filters.Add "Excel Files", "*.xls;*.xlw"
  8. .Filters.Add "All Files", "*.*" '设置两个文件过滤器
  9. .Show
  10. 'FileDialog 对象的 Show 方法显示对话框,并且返回 -1(如果您按 OK)和 0(如果您按 Cancel)。
  11. For l = 1 To .SelectedItems.Count
  12. MsgBox "您选择的文件是:" & .SelectedItems(l), vbOKOnly + vbInformation, "智能Excel"
  13. Next
  14. End With
  15. End Sub
Sub SelectFile()
    '选择多个文件
    Dim l As Long
    With Application.FileDialog(msoFileDialogFilePicker)
        .AllowMultiSelect = True   '单选择
        .Filters.Clear     '清除文件过滤器
        .Filters.Add "Excel Files", "*.xls;*.xlw"
        .Filters.Add "All Files", "*.*"    '设置两个文件过滤器
        .Show
        'FileDialog 对象的 Show 方法显示对话框,并且返回 -1(如果您按 OK)和 0(如果您按 Cancel)。
        For l = 1 To .SelectedItems.Count
            MsgBox "您选择的文件是:" & .SelectedItems(l), vbOKOnly + vbInformation, "智能Excel"
        Next
    End With
End Sub

2、msoFileDialogFolderPicker

文件夹仅能选择一个

 

Java代码 复制代码 收藏代码
  1. Sub SelectFolder()
  2. '选择单一文件
  3. With Application.FileDialog(msoFileDialogFolderPicker)
  4. If .Show = -1 Then
  5. 'FileDialog 对象的 Show 方法显示对话框,并且返回 -1(如果您按 OK)和 0(如果您按 Cancel)。
  6. MsgBox "您选择的文件夹是:" & .SelectedItems(1), vbOKOnly + vbInformation, "智能Excel"
  7. End If
  8. End With
  9. End Sub
Sub SelectFolder()
    '选择单一文件
    With Application.FileDialog(msoFileDialogFolderPicker)
        If .Show = -1 Then
        'FileDialog 对象的 Show 方法显示对话框,并且返回 -1(如果您按 OK)和 0(如果您按 Cancel)。
            MsgBox "您选择的文件夹是:" & .SelectedItems(1), vbOKOnly + vbInformation, "智能Excel"
        End If
    End With
End Sub

 

3、msoFileDialogOpen
4、msoFileDialogSaveAs

使用方法与前两种相同
只是在.show可以用.Execute方法来实际打开或者保存文件。

例如:

 

Java代码 复制代码 收藏代码
  1. Sub SelectFile()
  2. '选择单一文件
  3. With Application.FileDialog(msoFileDialogFilePicker)
  4. .AllowMultiSelect = False '单选择
  5. .Filters.Clear '清除文件过滤器
  6. .Filters.Add "Excel Files", "*.xls;*.xlw"
  7. .Filters.Add "All Files", "*.*" '设置两个文件过滤器
  8. .Execute
  9. End With
  10. End Sub
Sub SelectFile()
    '选择单一文件
    With Application.FileDialog(msoFileDialogFilePicker)
        .AllowMultiSelect = False   '单选择
        .Filters.Clear   '清除文件过滤器
        .Filters.Add "Excel Files", "*.xls;*.xlw"
        .Filters.Add "All Files", "*.*"          '设置两个文件过滤器
       .Execute
    End With
End Sub

 

 

另见:

 

《用Excel VBA选择文件、高容错性地打开文件》