Want to protect your cyber security and still get fast solutions? Ask a secure question today.Go Premium

x
  • Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 191
  • Last Modified:

Shell Command

Private Sub Form_Activate()
Dim openexcel
         
        openexcel = Shell("c:\Program Files\Microsoft Office\Office\excel c:\my documents\the worksheet.XLS", 1)
        AppActivate
       
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?

Thanks
0
thien
Asked:
thien
1 Solution
 
mark2150Commented:
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.

0
 
thienAuthor Commented:
This does not work.  Tells me file is not found.  

David
0
 
dishaCommented:
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 ..it is working fine. check what ver of excel u r using and if it cannot accept filename as spaced in between.
Regards

0
Concerto Cloud for Software Providers & ISVs

Can Concerto Cloud Services help you focus on evolving your application offerings, while delivering the best cloud experience to your customers? From DevOps to revenue models and customer support, the answer is yes!

Learn how Concerto can help you.

 
thienAuthor Commented:
Hi,

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.

Thanks
0
 
a111a111a111Commented:
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 = "*.*"
     CommonDialog1.ShowOpen
     
     msg = "Long File Name: " & CommonDialog1.filename & vbCrLf
     msg = msg & "Short File Name: " & GetShortName(CommonDialog1.filename)
     msg = msg & vbCrLf & "________________________________________________________"
     msg = msg & vbCrLf & vbCrLf & "http://www.hili.com/~shay   E-Mail: shayplace@hotmail.com"
     
     MsgBox msg
End Sub

Private Sub Command2_Click()
Unload Me
End Sub

Private Sub Form_Load()

End Sub




0
 
a111a111a111Commented:
Also you can download the exe from
http://www.hili.com/~shay/filename.zip
0
 
a111a111a111Commented:
You can modify the code as you wish.

0
 
thienAuthor Commented:
Thank you This is Exactly What I need!
0

Featured Post

Concerto Cloud for Software Providers & ISVs

Can Concerto Cloud Services help you focus on evolving your application offerings, while delivering the best cloud experience to your customers? From DevOps to revenue models and customer support, the answer is yes!

Learn how Concerto can help you.

Tackle projects and never again get stuck behind a technical roadblock.
Join Now