L
Laurent
Guest
Bonjour à tous,
Je fais sélectionner un dossier par utilisateur via un mini browser en utilisant api windows.
comment faire pour que l'utilisiteur n'ait pas toute l'arboressance à dérouler sachant qu'il probable que dans la même macro il ouvre des répertoire proches.( pas de changement de racine ca interdit de remonter l'arboressance!)?
Merci d'avance.
le code :
Public Dossier
Public Type BROWSEINFO
hOwner As Long
pidlRoot As Long
pszDisplayName As String
lpszTitle As String
ulFlags As Long
lpfn As Long
lParam As Long
iImage As Long
End Type
'32-bit API declarations
Declare Function SHGetPathFromIDList Lib 'shell32.dll' _
Alias 'SHGetPathFromIDListA' (ByVal pidl As Long, ByVal pszPath As String) As Long
Declare Function SHBrowseForFolder Lib 'shell32.dll' _
Alias 'SHBrowseForFolderA' (lpBrowseInfo As BROWSEINFO) As Long
Function GetDirectory(Optional Msg) As String
Dim bInfo As BROWSEINFO
Dim path As String
Dim r As Long, x As Long, pos As Integer
bInfo.pidlRoot = 0&
bInfo.lpszTitle = Msg
bInfo.ulFlags = &H1
x = SHBrowseForFolder(bInfo)
path = Space$(512)
r = SHGetPathFromIDList(ByVal x, ByVal path)
If r Then
pos = InStr(path, Chr$(0))
GetDirectory = Left(path, pos - 1)
Dossier = GetDirectory & '\\'
Else
'GetDirectory = ''
Dossier = ''
End If
End Function
appel fonction :
Ouverture_dossier:
GetDirectory (Message) 'appel de la fonction ouverture dossier avec message d'ouverture
Set fs = Application.FileSearch
With fs
.LookIn = Dossier
.Filename = '*.csv' 'ne recherche que les fichier csv
If .Execute() > 0 Then
M = .FoundFiles.Count
For J = 1 To M
'MsgBox .FoundFiles(J)
Workbooks.Open .FoundFiles(J), local:=True
Next J
ect...
Je fais sélectionner un dossier par utilisateur via un mini browser en utilisant api windows.
comment faire pour que l'utilisiteur n'ait pas toute l'arboressance à dérouler sachant qu'il probable que dans la même macro il ouvre des répertoire proches.( pas de changement de racine ca interdit de remonter l'arboressance!)?
Merci d'avance.
le code :
Public Dossier
Public Type BROWSEINFO
hOwner As Long
pidlRoot As Long
pszDisplayName As String
lpszTitle As String
ulFlags As Long
lpfn As Long
lParam As Long
iImage As Long
End Type
'32-bit API declarations
Declare Function SHGetPathFromIDList Lib 'shell32.dll' _
Alias 'SHGetPathFromIDListA' (ByVal pidl As Long, ByVal pszPath As String) As Long
Declare Function SHBrowseForFolder Lib 'shell32.dll' _
Alias 'SHBrowseForFolderA' (lpBrowseInfo As BROWSEINFO) As Long
Function GetDirectory(Optional Msg) As String
Dim bInfo As BROWSEINFO
Dim path As String
Dim r As Long, x As Long, pos As Integer
bInfo.pidlRoot = 0&
bInfo.lpszTitle = Msg
bInfo.ulFlags = &H1
x = SHBrowseForFolder(bInfo)
path = Space$(512)
r = SHGetPathFromIDList(ByVal x, ByVal path)
If r Then
pos = InStr(path, Chr$(0))
GetDirectory = Left(path, pos - 1)
Dossier = GetDirectory & '\\'
Else
'GetDirectory = ''
Dossier = ''
End If
End Function
appel fonction :
Ouverture_dossier:
GetDirectory (Message) 'appel de la fonction ouverture dossier avec message d'ouverture
Set fs = Application.FileSearch
With fs
.LookIn = Dossier
.Filename = '*.csv' 'ne recherche que les fichier csv
If .Execute() > 0 Then
M = .FoundFiles.Count
For J = 1 To M
'MsgBox .FoundFiles(J)
Workbooks.Open .FoundFiles(J), local:=True
Next J
ect...