List Box in Userforms

Waterpolo1

New Member
Joined
Sep 8, 2015
Messages
21
Hi Team,

Please could someone help with the following issue.

Context

- I have a useform which requires the user to upload documents to the userform. I have it at the moment so the filepath is shown.

Question

What is the best way to allow for multiple documents to be selected and thus multiple file paths to populate an excel cell in a workbook?

Current method

To find the file:

Private Sub CommandButton2_Click()
'GetOpenFile MultiSelect will return an Array if more than one is selected
Dim FilePathArray As Variant
FilePathArray = Application.GetOpenFilename(, , , , MultiSelect:=True)


If IsArray(FilePathArray) Then
Dim ArraySize As Long
ArraySize = UBound(FilePathArray, 1) - LBound(FilePathArray, 1) + 1

Dim ArrayPosition As Long
For ArrayPosition = 1 To ArraySize

If Not FilePathArray(ArrayPosition) = Empty Then

UserForm.ComboBoxEvidence.AddItem (FilePathArray(ArrayPosition))
End If

Next ArrayPosition
ElseIf FilePathArray <> False Then
'userform name is "userform"
UserForm.ComboBoxEvidence.AddItem (FilePathArray)

End If



This populates files selected into a list but has the following issues:

1.) Doesn't allow the user to delete a file if they make a mistake
2.) You can only submit one excel file to a spreadsheet

Many thanks for your support.

Joseph
 

Excel Facts

Excel Wisdom
Using a mouse in Excel is the work equivalent of wearing a lanyard when you first get to college
Hi Team,

Please could someone help with the following issue.

Context

- I have a useform which requires the user to upload documents to the userform. I have it at the moment so the filepath is shown.

Question

What is the best way to allow for multiple documents to be selected and thus multiple file paths to populate an excel cell in a workbook?

Current method

To find the file:

Private Sub CommandButton2_Click()
'GetOpenFile MultiSelect will return an Array if more than one is selected
Dim FilePathArray As Variant
FilePathArray = Application.GetOpenFilename(, , , , MultiSelect:=True)


If IsArray(FilePathArray) Then
Dim ArraySize As Long
ArraySize = UBound(FilePathArray, 1) - LBound(FilePathArray, 1) + 1

Dim ArrayPosition As Long
For ArrayPosition = 1 To ArraySize

If Not FilePathArray(ArrayPosition) = Empty Then

UserForm.ComboBoxEvidence.AddItem (FilePathArray(ArrayPosition))
End If

Next ArrayPosition
ElseIf FilePathArray <> False Then
'userform name is "userform"
UserForm.ComboBoxEvidence.AddItem (FilePathArray)

End If

This populates files selected into a list but has the following issues:

1.) Doesn't allow the user to delete a file if they make a mistake
2.) You can only submit one excel file to a spreadsheet

Many thanks for your support.

Joseph

Something like this maybe :
Code:
Dim FilePathArray As Variant

Private Sub CommandButton2_Click()

'GetOpenFile MultiSelect will return an Array if more than one is selected
FilePathArray = Application.GetOpenFilename(, , , , MultiSelect:=True)
If IsArray(FilePathArray) Then
Dim ArraySize As Long
ArraySize = UBound(FilePathArray, 1) - LBound(FilePathArray, 1) + 1
Dim ArrayPosition As Long
For ArrayPosition = 1 To ArraySize
If Not FilePathArray(ArrayPosition) = Empty Then
UserForm.ComboBoxEvidence.AddItem (FilePathArray(ArrayPosition))
End If
Next ArrayPosition
ElseIf FilePathArray <> False Then
'userform name is "userform"
UserForm.ComboBoxEvidence.AddItem (FilePathArray)
End If

[COLOR=#0000ff]If IsArray(FilePathArray) Then
    Range("a1") = "Selected Files"
    Range("a" & Rows.Count).End(xlUp).Offset(1).Resize(UBound(FilePathArray, 1)) = Application.Transpose(FilePathArray)
End If[/COLOR]
End Sub

[COLOR=#0000cd]Private Sub CommandButton3_Click() [B]'<== Undo Button[/B]
    If IsArray(FilePathArray) Then
        If Range("a" & Rows.Count).End(xlUp).Address <> "$A$1" Then
            Range("a" & Rows.Count).End(xlUp).Offset(-UBound(FilePathArray, 1) + 1).Resize(UBound(FilePathArray, 1)).ClearContents
        End If
    End If
End Sub[/COLOR]

The code assumes that the cells that are populated with the file names are in Column A of the activesheet.
 
Last edited:
Upvote 0

Forum statistics

Threads
1,225,757
Messages
6,186,850
Members
453,379
Latest member
gabriellegonzalez

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top