Still celebrating National IT Professionals Day with 3 months of free Premium Membership. Use Code ITDAY17


Shell Command

Posted on 1998-08-30
Medium Priority
Last Modified: 2010-04-30
Private Sub Form_Activate()
Dim openexcel
        openexcel = Shell("c:\Program Files\Microsoft Office\Office\excel c:\my documents\the worksheet.XLS", 1)
End Sub

This command will not work because long filenames and spaces between the folder "my documents" and "The worksheet.xls"  I know that if I type in the dos name "Mydocu~1" it will work, but I need to have this set to a variable, instead of hard code.  Is there a function that will convert these so the computer will know how to open?

Question by:thien
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
LVL 12

Expert Comment

ID: 1431911
Try phrasing it as:
quote = chr(34)
path = "c:\" & quote & "Program Files\Microsoft Office\Office\excel" & quote
file = "c:\" & quote & "my documents\the worksheet.XLS" & quote
openexcel = Shell(path & " " & file, 1)

In this way the quotes will be passed out to the SHELL command.


Author Comment

ID: 1431912
This does not work.  Tells me file is not found.  


Expert Comment

ID: 1431913
Hi David,
I dont think there is a problem with the command u have given because it works fine. Could u specify the exact error that it gives at u'r place.
Check out that excel works fine and also that the xls is present. I tried with other exe's is working fine. check what ver of excel u r using and if it cannot accept filename as spaced in between.

Technology Partners: 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!


Author Comment

ID: 1431914

Again it does not work,error 53, File not found.  If I use the command the regular way,

openexcel = Shell("c:\Program Files\Microsoft Office\Office\excel c:\worksheet.XLS", 1)

The example above works, but if I change the path to C:\my documents, or to a worksheet that has a space in the name, then I get errors.  Your example does not work. Even though I know the file exists, it tells me it does not.


Accepted Solution

a111a111a111 earned 200 total points
ID: 1431915
Here is a working code to get a short file name from a long file name.

The program and code are working fine.

If you need the exe I can email to you.

============  start here =============
' ***  in module1 ***
Option Explicit

Declare Function GetShortPathName Lib "kernel32" _
      Alias "GetShortPathNameA" (ByVal lpszLongPath As String, _
      ByVal lpszShortPath As String, ByVal cchBuffer As Long) As Long

   Public Function GetShortName(ByVal sLongFileName As String) As String
       Dim lRetVal As Long, sShortPathName As String, iLen As Integer
       'Set up buffer area for API function call return
       sShortPathName = Space(255)
       iLen = Len(sShortPathName)

       'Call the function
       lRetVal = GetShortPathName(sLongFileName, sShortPathName, iLen)
       'Strip away unwanted characters.
       GetShortName = Left(sShortPathName, lRetVal)
   End Function


' THe code in form1 ********

Option Explicit

Private Sub Command1_Click()
Dim msg As String
     CommonDialog1.filename = "*.*"
     msg = "Long File Name: " & CommonDialog1.filename & vbCrLf
     msg = msg & "Short File Name: " & GetShortName(CommonDialog1.filename)
     msg = msg & vbCrLf & "________________________________________________________"
     msg = msg & vbCrLf & vbCrLf & "   E-Mail:"
     MsgBox msg
End Sub

Private Sub Command2_Click()
Unload Me
End Sub

Private Sub Form_Load()

End Sub


Expert Comment

ID: 1431916
Also you can download the exe from

Expert Comment

ID: 1431917
You can modify the code as you wish.


Author Comment

ID: 1431918
Thank you This is Exactly What I need!

Featured Post

Independent Software Vendors: 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!

Question has a verified solution.

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

Enums (shorthand for ‘enumerations’) are not often used by programmers but they can be quite valuable when they are.  What are they? An Enum is just a type of variable like a string or an Integer, but in this case one that you create that contains…
If you need to start windows update installation remotely or as a scheduled task you will find this very helpful.
Get people started with the process of using Access VBA to control Outlook using automation, Microsoft Access can control other applications. An example is the ability to programmatically talk to Microsoft Outlook. Using automation, an Access applic…
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…
Suggested Courses

705 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