在批处理脚本中,我需要获取具有给定二进制路径的进程 ID 列表
C:\path\to\binary.exe
。
在 Linux 中,我可以这样做 pidof /path/to/binary
。
是否有具有相同功能的 Win32 可执行文件,支持从 WinXP Home 到 Win7(任务列表不起作用)?
包含此内容的软件包必须是可移植的,因此 10MB 的下载不是我想要的。
是否有可用的 C 函数可以做到这一点并且从 WinXP 到 Win7 都受支持?注意:我想匹配进程路径,而不是其他应用程序也可以使用的文件名。
wmic process where ExecutablePath='C:\\windows\\system32\\notepad.exe' get ProcessId
如果您也想支持 Windows XP Home,可以使用
EnumProcess 和 GetModuleFileNameEx。这里的缺点是,如果您不以管理员身份运行,您将无法查询其他用户运行的进程的名称。 QueryFullProcessImageName 可能可以解决这个问题,但它是 Vista+。
如果这还不够,您需要Process32First(swatkat 的代码)。对于每个进程,您需要调用Module32First,然后获取MODULEENTRY32->szExePath
。请注意,即使这也不是完全可移植的,并且在 x64 上也无法正常工作,您需要QueryFullProcessImageName。
int main( int argc, char* argv[] )
{
if( argc > 1 )
{
printf( "\nGetting PID of: %s\n", argv[1] );
HANDLE hProcSnapshot = ::CreateToolhelp32Snapshot( TH32CS_SNAPPROCESS, 0 );
if( INVALID_HANDLE_VALUE != hProcSnapshot )
{
PROCESSENTRY32 procEntry = {0};
procEntry.dwSize = sizeof(PROCESSENTRY32);
if( ::Process32First( hProcSnapshot, &procEntry ) )
{
do
{
HANDLE hModSnapshot = ::CreateToolhelp32Snapshot( TH32CS_SNAPMODULE, procEntry.th32ProcessID );
if( INVALID_HANDLE_VALUE != hModSnapshot )
{
MODULEENTRY32 modEntry = {0};
modEntry.dwSize = sizeof( MODULEENTRY32 );
if( Module32First( hModSnapshot, &modEntry ) )
{
if( 0 == stricmp( argv[1], modEntry.szExePath ) )
{
printf( "\nPID: %ld\n", procEntry.th32ProcessID );
::CloseHandle( hModSnapshot );
break;
}
}
::CloseHandle( hModSnapshot );
}
}
while( ::Process32Next( hProcSnapshot, &procEntry ) );
}
::CloseHandle( hProcSnapshot );
}
}
return 0;
}
Process.GetProcessesByName(String) ,然后检查结果并在 MainModule.FileName 等于您正在查找的路径时打印每个结果的 Id 属性为.
param($fileName)
Get-Process | where -FilterScript {$_.MainModule.FileName -eq $fileName}
此脚本将接收一个参数,即您正在查找的文件名,并且它将输出其可执行文件的文件名。
您可以通过执行以下操作从bat文件中调用它:
powershell -Command "& {Get-Process | where -FilterScript {$_.MainModule.FileName -eq %FILENAME%}"
pidof
并以进程名称作为参数。我以前不需要可执行路径。我这样使用它:
pidof php
它只是返回正在运行的进程的PID。与 PowerShell 类似,我可以按如下方式使用它:
(get-process php).id
它会像 pidof
一样返回 PID。