2009-08-28 169 views

回答

18

这个Windows API是GetBinaryType。您可以使用pywin32从Python中调用这个:

import win32file 
type=GetBinaryType("myfile.exe") 
if type==win32file.SCS_32BIT_BINARY: 
    print "32 bit" 
# And so on 

如果你想做到这一点没有pywin32,你必须自己阅读PE header。下面是an example在C#中,这里有一个快速的端口到Python:

import struct 

IMAGE_FILE_MACHINE_I386=332 
IMAGE_FILE_MACHINE_IA64=512 
IMAGE_FILE_MACHINE_AMD64=34404 

f=open("c:\windows\explorer.exe", "rb") 

s=f.read(2) 
if s!="MZ": 
    print "Not an EXE file" 
else: 
    f.seek(60) 
    s=f.read(4) 
    header_offset=struct.unpack("<L", s)[0] 
    f.seek(header_offset+4) 
    s=f.read(2) 
    machine=struct.unpack("<H", s)[0] 

    if machine==IMAGE_FILE_MACHINE_I386: 
     print "IA-32 (32-bit x86)" 
    elif machine==IMAGE_FILE_MACHINE_IA64: 
     print "IA-64 (Itanium)" 
    elif machine==IMAGE_FILE_MACHINE_AMD64: 
     print "AMD64 (64-bit x86)" 
    else: 
     print "Unknown architecture" 

f.close() 
+0

这将是很好,如果我可以不使用pywin32模块获得这些信息。 – pkit 2009-08-28 08:37:59

+1

刚刚编辑了答案,以显示如何在没有pywin32的情况下执行此操作。 – 2009-08-28 08:47:21

+0

@马丁。感谢您的链接,我会看看我是否可以把一些东西放在一起。 – pkit 2009-08-28 08:49:42

4

如果你在Windows上运行的Python 2.5或更高版本,您还可以通过使用ctypes的使用Windows API不pywin32。

from ctypes import windll, POINTER 
from ctypes.wintypes import LPWSTR, DWORD, BOOL 

SCS_32BIT_BINARY = 0 # A 32-bit Windows-based application 
SCS_64BIT_BINARY = 6 # A 64-bit Windows-based application 
SCS_DOS_BINARY = 1 # An MS-DOS-based application 
SCS_OS216_BINARY = 5 # A 16-bit OS/2-based application 
SCS_PIF_BINARY = 3 # A PIF file that executes an MS-DOS-based application 
SCS_POSIX_BINARY = 4 # A POSIX-based application 
SCS_WOW_BINARY = 2 # A 16-bit Windows-based application 

_GetBinaryType = windll.kernel32.GetBinaryTypeW 
_GetBinaryType.argtypes = (LPWSTR, POINTER(DWORD)) 
_GetBinaryType.restype = BOOL 

def GetBinaryType(filepath): 
    res = DWORD() 
    handle_nonzero_success(_GetBinaryType(filepath, res)) 
    return res 

然后像使用win32file.GetBinaryType一样使用GetBinaryType。

注意,你必须实现handle_nonzero_success,基本上抛出一个异常,如果返回值是0。

0

我能够在Python 3.5程序成功地使用马丁B的回答作出这个调整后:

s=f.read(2).decode(encoding="utf-8", errors="strict") 

最初它在Python 2.7的程序中工作得很好,但是在做了其他必要的修改之后,我发现我得到了b'MZ,解码它似乎解决了这个问题。

相关问题