Python实现鼠标点击获取窗口进程信息

最近遇到挺无解的一个问题:电脑上莫名其妙出现一个白色小方块,点击没有反应,关也关不掉,想知道它和哪个软件有关还是显卡出了问题,也找不到思路,就想着要不获取一下它的进程号看看。

于是写了一个Python脚本,可以通过鼠标点击快速获取任意窗口的详细信息,包括窗口标题、进程PID和程序路径。特别适合需要快速定位窗口来源或排查异常进程的场景。

使用方法

  1. 运行脚本后,屏幕会提示:点击任意窗口开始检测 (按Ctrl+C退出)...

  2. 将鼠标移动到目标窗口上方并点击

  3. 控制台立即显示类似以下信息:

    窗口标题: 无标题 - 记事本
    进程PID: 1234
    程序路径: C:\Windows\System32\notepad.exe

实现原理

  1. 核心组件

    • pynput:监听全局鼠标点击事件
    • pywin32:获取窗口句柄和进程ID
    • psutil:查询进程详细信息
  2. 技术流程

    • 鼠标点击时捕获坐标位置
    • 通过WindowFromPoint获取对应窗口句柄
    • 使用GetWindowThreadProcessId提取进程ID
    • 通过psutil查询进程可执行文件路径
    • 最后输出窗口标题和进程信息

安装依赖

复制代码
pip install pynput pywin32 psutil

注意事项

  1. 需要Windows系统运行
  2. 获取系统级窗口(如任务栏)可能显示路径为Unknown
  3. 某些受保护进程可能需要管理员权限运行脚本
  4. 点击速度过快可能导致坐标捕获偏差,建议点击后稍作停顿

完整代码

复制代码
import win32gui
import win32process
import psutil
import signal
import sys
from pynput import mouse

def signal_handler(sig, frame):
    print("\n程序已退出")
    sys.exit(0)

def get_window_info(x, y):
    hwnd = win32gui.WindowFromPoint((x, y))
    _, pid = win32process.GetWindowThreadProcessId(hwnd)
    
    try:
        process = psutil.Process(pid)
        exe_path = process.exe()
    except psutil.NoSuchProcess:
        exe_path = "Unknown"
    
    title = win32gui.GetWindowText(hwnd)
    return pid, exe_path, title

def on_click(x, y, button, pressed):
    if pressed:
        pid, exe, title = get_window_info(x, y)
        print(f"窗口标题: {title}")
        print(f"进程PID: {pid}")
        print(f"程序路径: {exe}\n")

# 注册信号处理
signal.signal(signal.SIGINT, signal_handler)

with mouse.Listener(on_click=on_click) as listener:
    print("点击任意窗口开始检测 (按Ctrl+C退出)...")
    try:
        listener.join()
    except KeyboardInterrupt:
        pass

于是破案:PowerToys!

相关推荐
蛋仔聊测试6 分钟前
Playwright 中 Page 对象的常用方法详解
python
醇醛酸醚酮酯13 分钟前
Qt项目锻炼——TODO清单(二)
开发语言·数据库·qt
前端付豪18 分钟前
17、自动化才是正义:用 Python 接管你的日常琐事
后端·python
jioulongzi19 分钟前
记录一次莫名奇妙的跨域502(badgateway)错误
开发语言·python
破无差1 小时前
python实现简单的地图绘制与标记20250705
python
向阳@向远方1 小时前
第二章 简单程序设计
开发语言·c++·算法
喜欢吃豆1 小时前
目前最火的agent方向-A2A快速实战构建(二): AutoGen模型集成指南:从OpenAI到本地部署的全场景LLM解决方案
后端·python·深度学习·flask·大模型
Mr_Xuhhh1 小时前
信号与槽的总结
java·开发语言·数据库·c++·qt·系统架构
纳兰青华2 小时前
bean注入的过程中,Property of ‘java.util.ArrayList‘ type cannot be injected by ‘List‘
java·开发语言·spring·list
好开心啊没烦恼2 小时前
Python 数据分析:DataFrame,生成,用字典创建 DataFrame ,键值对数量不一样怎么办?
开发语言·python·数据挖掘·数据分析