如何从VBA的“文件对话框"对象中获取单个文件名(对于MS Access 2007)? [英] How do I get a single file name out of a File Dialog object in VBA (for MS Access 2007)?
本文介绍了如何从VBA的“文件对话框"对象中获取单个文件名(对于MS Access 2007)?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
如何更改代码以获取文件名而不是目录名? openDialog.InitialFilename
给我目录名称.
openDialog.FileName
给我错误找不到方法或数据成员".
How do I change my code to get the file name instead of the directory name? openDialog.InitialFilename
gives me the directory name.
openDialog.FileName
gives me the error "Method or data member not found".
Private Sub btnEditPhoto_Click()
If (txtImageName > "") Then
Application.FollowHyperlink txtImageName
Else
Dim openDialog As Office.FileDialog
Set openDialog = Application.FileDialog(msoFileDialogFilePicker)
openDialog.Filters.Clear
openDialog.Filters.Add "JPEG Files", "*.jpg"
Dim pickedFile As Boolean
pickedFile = openDialog.Show
If pickedFile Then
txtImageName.SetFocus
txtImageName.Text = openDialog.InitialFileName
End If
End If
End Sub
推荐答案
您要:
OpenDialog.SelectedItems.Item(1)
代替:
OpenDialog.InitialFileName
因为您不允许多选.
所以:
''Reference Microsoft Office x.x Object Library
Dim openDialog As Office.FileDialog
Set openDialog = Application.FileDialog(msoFileDialogFilePicker)
openDialog.Filters.Clear
openDialog.Filters.Add "JPEG Files", "*.jpg"
If openDialog.Show Then
''SelectedItems is not zero based
''Do not use .Text property in MS Access except
''in special cases, then you will not have to set focus
''txtImageName.SetFocus
txtImageName = openDialog.SelectedItems(1)
End If
如果使用AllowMultiSelect,则需要遍历SelectedItems
If AllowMultiSelect is used, you need to iterate through SelectedItems
''Reference Microsoft Office x.x Object Library
Dim openDialog As Office.FileDialog
Dim i As Integer
Set openDialog = Application.FileDialog(msoFileDialogFilePicker)
'Use ctl or shift + click to select more than one file
openDialog.AllowMultiSelect = True
openDialog.Filters.Clear
openDialog.Filters.Add "JPEG Files", "*.jpg"
If openDialog.Show Then
For i = 1 To openDialog.SelectedItems.Count
Imagelst = Imagelst & ";" & openDialog.SelectedItems(i)
Next
End If
这篇关于如何从VBA的“文件对话框"对象中获取单个文件名(对于MS Access 2007)?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文