Atlanta Custom Software Development 

 
   Search        Code/Page
 

User Login
Email

Password

 

Forgot the Password?
Services
» Web Development
» Maintenance
» Data Integration/BI
» Information Management
Programming
  Database
Automation
OS/Networking
Graphics
Links
Tools
» Regular Expr Tester
» Free Tools

How to open a file with Wordpad or Notepad
[ All Languages » VB »  Shell]

Total Hit ( 2894)

Rate this article:     Poor     Excellent 

 Submit Your Question/Comment about this article

Rating


 


I tried to find sourcecode which allows me to open a file with any extension with Wordpad and Notepad. And finally I came up with this solution.


Happy Programming....

Click here to copy the following block
Option Explicit
Private Declare Function FindExecutable Lib "shell32.dll" _
  Alias "FindExecutableA" _
 (ByVal lpFile As String, _
  ByVal lpDirectory As String, _
  ByVal sResult As String) As Long

Private Sub Command1_Click()
  
  OpenWithWordPad "d:\t1.txt"
  
  OpenWithNotePad "d:\t1.txt"
  
End Sub

Public Function OpenWithWordPad(strPath As String) As Boolean
  Dim lRet As Long
  lRet = Shell(AssociatedEXE("WRI") & " " _
    & strPath, vbNormalFocus)
End Function

Public Function OpenWithNotePad(strPath As String) As Boolean
  Dim lRet As Long
  lRet = Shell(AssociatedEXE("TXT") & " " _
    & strPath, vbNormalFocus)
End Function

Public Function AssociatedEXE(Ext As String) As String
  Dim iFN             As Integer
  Dim lRet             As Long
  Dim szResult           As String
  Dim szTmpFile          As String
  Const MAX_PATH          As Long = 260
  Const FE_SUCCESS         As Long = 32
  '-------------------------------------------------
  On Error GoTo errAssociatedEXE
  szResult = Space$(MAX_PATH)
  iFN = FreeFile
  szTmpFile = HomeDirectory() & "AE_TMP." & Ext
  If FileExists(szTmpFile) Then
   Kill (szTmpFile): DoEvents
  End If
  Open szTmpFile For Random As #iFN
  Close #iFN: DoEvents
  lRet = FindExecutable(szTmpFile, "", szResult)
  If (lRet >= FE_SUCCESS) Then
   lRet = InStr(szResult, Chr$(0))
   If (lRet > 0) Then
     szResult = Left$(szResult, lRet - 1)
   End If
  End If
  szResult = Trim$(szResult)
  If FileExists(szTmpFile) Then
   Kill (szTmpFile): DoEvents
  End If
  AssociatedEXE = szResult
Exit Function
errAssociatedEXE:
  Close #iFN
  Resume Next
End Function

Public Function HomeDirectory() As String
  HomeDirectory = App.Path & IIf(Right$(App.Path, 1) = "\", "", "\")
End Function

Public Function FileExists(ByVal szFileName As String) As Boolean
' ///////////////////////////////////////////////////
' Purpose: See function name            '/
' Parameters: String containing file name     '/
' Return Value: True/False             '/
'////////////////////////////////////////////////////
  Dim AttrRet     As Integer
  Dim bIsDirectory  As Boolean
  '------------------------------------------------
  On Error Resume Next
  AttrRet = GetAttr(szFileName)
  If Err.Number Then
   Err.Clear
   FileExists = False
  Else
   bIsDirectory = CBool((AttrRet And vbDirectory) = vbDirectory)
   If (bIsDirectory = False) Then
     FileExists = True
   Else
     FileExists = False
   End If
  End If
End Function


Submitted By : Nayan Patel  (Member Since : 5/26/2004 12:23:06 PM)

Job Description : He is the moderator of this site and currently working as an independent consultant. He works with VB.net/ASP.net, SQL Server and other MS technologies. He is MCSD.net, MCDBA and MCSE. In his free time he likes to watch funny movies and doing oil painting.
View all (893) submissions by this author  (Birth Date : 7/14/1981 )


Home   |  Comment   |  Contact Us   |  Privacy Policy   |  Terms & Conditions   |  BlogsZappySys

© 2008 BinaryWorld LLC. All rights reserved.