VBA Excel OpenDialogBox then Transfer the information to cell

Daniza Morla

New Member
Joined
Jul 28, 2018
Messages
3
Hi 😜 Hello, when I incorporate this code as an add-in within Excel, the data doesn't transfer to cells B12, B14, and B16 as expected. However, when I place the code in a module within the workbook itself, it works correctly.

1. Prompt the user to select an Excel file using the file dialog box.
2. Open the selected Excel file.
3. Retrieve the file location, file name, and the name of the first sheet in the Excel file.
4. Place this information in specific cells of a worksheet (Sheet3 using codename).
5. Close the selected workbook and quit Excel.
6. Display a message box informing the user that the process is complete.

Thank you 🙏


VBA Code:
Sub SelectExcelFile_()
    Dim selectedFile As Variant
    Dim fileLocation As String
    Dim excelApp As Object
    Dim Workbook As Object
    
    ' Open the file dialog box
    With Application.FileDialog(msoFileDialogFilePicker)
        .AllowMultiSelect = False
        .Title = "Select an Excel File"
        
        ' Show only Excel files in the dialog box
        .Filters.Clear
        .Filters.Add "Excel Files", "*.xls; *.xlsx; *.xlsm"
        
        If .Show = -1 Then ' User clicked OK
            ' Get the selected file path
            selectedFile = .SelectedItems(1)
            
            ' Create an instance of Excel and open the selected file
            Set excelApp = CreateObject("Excel.Application")
            Set Workbook = excelApp.Workbooks.Open(selectedFile)
            
            ' Get the file location
            fileLocation = Left(selectedFile, InStrRev(selectedFile, "\") - 1)
            
            ' Place the file location, file name, and sheet name in cells B12, B14, and B16 respectively
            Sheet3.Range("B12").Value = fileLocation
            Sheet3.Range("B14").Value = Workbook.Name
            Sheet3.Range("B16").Value = Workbook.Sheets(1).Name
            
            ' Close the selected workbook and quit Excel
            Workbook.Close
            excelApp.Quit
            
            ' Clean up the objects
            Set Workbook = Nothing
            Set excelApp = Nothing
            MsgBox "Done, Updating File Location.." & vbCrLf & vbCrLf & "Please Open the file:" & vbCrLf & Sheet3.Range("B14").Value, vbInformation, "Successful _path Folder Location."
        End If
    End With
End Sub
 

Excel Facts

What is =ROMAN(40) in Excel?
The Roman numeral for 40 is XL. Bill "MrExcel" Jelen's 40th book was called MrExcel XL.
Sheet3.Range("B12") .. etc will refer to sheets in the addin.

Maybe you should fully qualify the sheets so they refer to the current workbook:

ThisWorkbook.Sheets("Sheet3").Range("B12").Value = fileLocation
 
Upvote 1
Sheet3.Range("B12") .. etc will refer to sheets in the addin.

Maybe you should fully qualify the sheets so they refer to the current workbook:

ThisWorkbook.Sheets("Sheet3").Range("B12").Value = fileLocation
Oops. stupid mistake!
It should be:
VBA Code:
ActiveWorkbook.Sheets("Sheet3").Range("B12").Value = fileLocation
 
Upvote 1
VBA Code:
ActiveWorkbook.Sheets("Sheet3").Range("B12").Value = fileLocation

I try this one but, Code stop on this line getting run time error 9, subscription out of range :cry:

Code:
ThisWorkbook.Sheets("Sheet3").Range("B12").Value = fileLocation

Also tried this one but code run until the last part, but no data was transfer on the cell :confused:
 
Upvote 0
VBA Code:
ActiveWorkbook.Sheets("Sheet3").Range("B12").Value = fileLocation

I try this one but, Code stop on this line getting run time error 9, subscription out of range :cry:

Code:
ThisWorkbook.Sheets("Sheet3").Range("B12").Value = fileLocation

Also tried this one but code run until the last part, but no data was transfer on the cell :confused:
Make sure you pass the actual sheet name (not the code name) where you want the values to be transferred:

ActiveWorkbook.Sheets("Actual Sheet Name Goes Here").Range("B12").Value = fileLocation
 
Upvote 1
Solution

Forum statistics

Threads
1,225,734
Messages
6,186,715
Members
453,369
Latest member
positivemind

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