getting path

Posted on 2000-05-02
Medium Priority
Last Modified: 2010-05-02
Hi all,
I would like to know, is there any function just like "GETDIR()" in Visual Fox Pro, which let users to choose path and return the path as a string?

Question by:chuyan
  • 2
  • 2
  • 2
  • +3

Expert Comment

ID: 2768545
Yes, there ia a function for user to choose path and return the path as string. the function is Dir().
LVL 143

Expert Comment

by:Guy Hengel [angelIII / a3]
ID: 2768635
dear wnchan: Dir() doesn't allow the user CHOOSE a path, but return the current path

I think what chuyan needs is a dialog box to Open/Save a File.
In this case, you can use the Common Dialog Control (look in components)

Hope this helps

Author Comment

ID: 2769925
yup, I think angelIII knows what  I need.  But I'm not sure that if common dialog box works.  Since I only want to let users to choose the directories only, I don't  want to let them input anything by typing.  I just want them to select their desired directory.  Could the common dialog box help?
Industry Leaders: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

LVL 143

Expert Comment

by:Guy Hengel [angelIII / a3]
ID: 2769940
In this case, not really.
You would need to implement your own dialog box using the drive control and the directory control and some buttons;
or try to find a free dialog box on sites like www.vbcontrol.com or www.vbaccelerator.com
Hope this helps
LVL 28

Expert Comment

ID: 2774212
use the dirlistbox control that is in your toolbox, to see how it works stick a dirlistbox on your form and a textbox and paste this code:

Private Sub Dir1_Change()
    Text1.Text = Dir1.Path
End Sub


Expert Comment

ID: 2776572
To try this example you need to add a textbox , commondialog control and a command button.
add this code in the form and run

Private Sub Command1_Click()
Text1 = CommonDialog1.FileName
End Sub

text1 will contain the path of the file which the user has chosen by clicking the command button.
Hope this will help you.

Accepted Solution

swoosh72 earned 20 total points
ID: 2777823
I'm not sure if I understand correctly what you are looking for, but try this.
Create a new VB Project.
Under the project menu click components. When the box loads, scroll down to find one called Microsoft Common Dialog Control. Check this option and click ok. It's now listed in your toolbox as a small window icon.

Add one to your form.

Once this is done, add the following code to your form's (General) (Declaration) section.

Option Explicit
Private Const MAX_PATH = 260

Private Declare Function SHBrowseForFolder Lib _
        "shell32" (lpbi As BrowseInfo) As Long

Private Declare Function SHGetPathFromIDList Lib _
        "shell32" (ByVal pidList As Long, ByVal lpBuffer _
        As String) As Long

Private Declare Function lstrcat Lib "kernel32" _
        Alias "lstrcatA" (ByVal lpString1 As String, ByVal _
        lpString2 As String) As Long

Private Type BrowseInfo
        hWndOwner As Long
        pIDLRoot As Long
        pszDisplayName As Long
        lpszTitle As Long
        ulFlags As Long
        lpfnCallback As Long
        lParam As Long
        iImage As Long
End Type

Now add a command button to your form.
Make sure it's named Command1

Copy the following code into the Command1 Click event.
    '     displays the
    'directories in your computer
    Dim lpIDList As Long ' Declare Varibles
    Dim sBuffer As String
    Dim szTitle As String
    Dim tBrowseInfo As BrowseInfo
    szTitle = "Hello World. Click On a directory and " & _
        "it's path will be displayed In a message box"
    ' Text to appear in the the gray area un
    '     der the title bar
    ' telling you what to do

    With tBrowseInfo
            .hWndOwner = Me.hWnd ' Owner Form
            .lpszTitle = lstrcat(szTitle, "")
    End With
    lpIDList = SHBrowseForFolder(tBrowseInfo)

    If (lpIDList) Then
            sBuffer = Space(MAX_PATH)
            SHGetPathFromIDList lpIDList, sBuffer
            sBuffer = Left(sBuffer, InStr(sBuffer, vbNullChar) - 1)
            MsgBox sBuffer
    End If

Run the program and click the button.
You will be prompted with a browse for folder box and you will it will return it's path. Let me know how it works out.

LVL 28

Expert Comment

ID: 2777847
swoosh welcome to EE. it is customary to just post comments here.  the questioner can accept a comment as an answer at any time.

Expert Comment

ID: 2777874
Thanks dude. I'm new here and I appreciate the tip.

Featured Post

Free Tool: Path Explorer

An intuitive utility to help find the CSS path to UI elements on a webpage. These paths are used frequently in a variety of front-end development and QA automation tasks.

One of a set of tools we're offering as a way of saying thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Introduction While answering a recent question (http://www.experts-exchange.com/Q_27402310.html) in the VB classic zone, I wrote some VB code in the (Office) VBA environment, rather than fire up my older PC.  I didn't post completely correct code o…
This article describes some techniques which will make your VBA or Visual Basic Classic code easier to understand and maintain, whether by you, your replacement, or another Experts-Exchange expert.
Show developers how to use a criteria form to limit the data that appears on an Access report. It is a common requirement that users can specify the criteria for a report at runtime. The easiest way to accomplish this is using a criteria form that a…
This lesson covers basic error handling code in Microsoft Excel using VBA. This is the first lesson in a 3-part series that uses code to loop through an Excel spreadsheet in VBA and then fix errors, taking advantage of error handling code. This l…
Suggested Courses

807 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question