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 小时前
别再记命令了,用 yeero do 说句人话就能跑脚本,而且不烧 token
服务器·python·命令行
Agent_大师6 小时前
WebSocket 行情重连成功,K线缺口不会自动消失
python
荣码6 小时前
LLM结构化输出:让AI返回JSON而不是废话,我踩了4个坑
java·python
copyer_xyf7 小时前
FastAPI 如何连接 MySQL
后端·python
apocelipes20 小时前
常用编程语言和库的正则表达式性能对比
c语言·c++·python·性能优化·golang·开发工具和环境
用户8356290780511 天前
使用 Python 在 PDF 中创建与管理书签
后端·python
MeixianAgent1 天前
Python 回测数据入口怎么验?历史 K 线入库前先做 5 个检查
后端·python
咕白m6251 天前
用 Python 实现一键批量查找与替换 Excel 数据
后端·python
SelectDB2 天前
Apache Doris Python UDF:让 SQL 直接调用 Python 生态,支撑 Agent 时代复杂业务逻辑
大数据·数据库·python
荣码2 天前
GraphRAG:普通RAG只能回答"点"的问题,我踩了4个坑才搞懂
java·python