为你专门写了一个获取文件版本号的函数,如下:
Option Explicit
Private Type VS_FIXEDFILEINFO
dwSignature As Long
dwStrucVersionl As Integer
dwStrucVersionh As Integer
dwFileVersionMSl As Integer
dwFileVersionMSh As Integer
dwFileVersionLSl As Integer
dwFileVersionLSh As Integer
dwProductVersionMSl As Integer
dwProductVersionMSh As Integer
dwProductVersionLSl As Integer
dwProductVersionLSh As Integer
dwFileFlagsMask As Long
dwFileFlags As Long
dwFileOS As Long
dwFileType As Long
dwFileSubtype As Long
dwFileDateMS As Long
dwFileDateLS As Long
End Type
Private Declare Function GetFileVersionInfo Lib "Version.dll" Alias "GetFileVersionInfoA" (ByVal lptstrFilename As String, ByVal dwhandle As Long, ByVal dwlen As Long, lpData As Any) As Long
Private Declare Function GetFileVersionInfoSize Lib "Version.dll" Alias "GetFileVersionInfoSizeA" (ByVal lptstrFilename As String, lpdwHandle As Long) As Long
Private Declare Function VerQueryValue Lib "Version.dll" Alias "VerQueryValueA" (pBlock As Any, ByVal lpSubBlock As String, lplpBuffer As Any, puLen As Long) As Long
Private Declare Sub MoveMemory Lib "kernel32" Alias "RtlMoveMemory" (dest As Any, ByVal Source As Long, ByVal length As Long)
Function GetVersion(ByVal FullFileName As String) As String
Dim FileVersionLen As Long, fInfor() As Byte, lVerPointer As Long, udtVerBuffer As VS_FIXEDFILEINFO
Dim i As Long
FileVersionLen = GetFileVersionInfoSize(FullFileName, 0)
If FileVersionLen < 1 Then
GetVersion = ""
Exit Function
End If
ReDim fInfor(FileVersionLen)
i = GetFileVersionInfo(FullFileName, 0, FileVersionLen, fInfor(0))
i = VerQueryValue(fInfor(0), "\", lVerPointer, FileVersionLen)
MoveMemory udtVerBuffer, lVerPointer, Len(udtVerBuffer)
GetVersion = Trim(Str(udtVerBuffer.dwFileVersionMSh)) + "." + Trim(Str(udtVerBuffer.dwFileVersionMSl)) + "." + Str((udtVerBuffer.dwFileVersionLSh)) + "." + Trim(Str((udtVerBuffer.dwFileVersionLSl)))
End Function