python pynput实现鼠标点击两坐标生成截图

脚本主要实现以下功能:

  • 按ctrl开始截图,点击两个坐标,保存截图

  • tk输出截图文本信息,文本输出内容倒序处理

  • 默认命名为A0自增。支持自定义名称,自增编号,修改自定义名称自增重新计算

  • 清空文本框内容

    from pynput import mouse, keyboard
    from PIL import ImageGrab
    import tkinter as tk

    使用字典来维护每个自定义名称的截图计数

    screenshot_counts = {}

    def start_screenshot(text_widget, name_entry):
    positions = []

    复制代码
      def on_click(x, y, button, pressed):
          if not pressed:
              # 当鼠标松开时记录位置
              positions.append((x, y))
              text_widget.insert('1.0', f'坐标为{x},{y}\n')
              # 如果已经记录了两个位置,就停止监听
              if len(positions) == 2:
                  return False
    
      # 开始监听鼠标
      with mouse.Listener(on_click=on_click) as listener:
          listener.join()
    
      if len(positions) == 2:
          # 确保截图区域的坐标是正确的
          left = min(positions[0][0], positions[1][0])
          top = min(positions[0][1], positions[1][1])
          right = max(positions[0][0], positions[1][0])
          bottom = max(positions[0][1], positions[1][1])
    
          # 使用PIL的ImageGrab模块的grab函数来截图
          screenshot = ImageGrab.grab((left, top, right, bottom))
    
          # 获取用户输入的名称
          screenshot_name = name_entry.get()
    
          # 如果用户没有输入名称,使用默认的名称"A"
          if screenshot_name == "":
              screenshot_name = "A"
          # 检查名称是否存在于字典中,如果不存在,初始化计数值
          if screenshot_name not in screenshot_counts:
              screenshot_counts[screenshot_name] = 0
          # 根据名称获取对应的计数值
          count = screenshot_counts[screenshot_name]
          screenshot_name_with_count = f"{screenshot_name}{count}.png"
    
          # 保存截图
          screenshot.save(screenshot_name_with_count)
          text_widget.insert('1.0', f'截图已保存为{screenshot_name_with_count}\n')
          text_widget.insert('1.0', f'#--------\n')
          text_widget.insert('1.0', f'\n')
    
          # 增加对应名称的截图计数
          screenshot_counts[screenshot_name] += 1

    def on_release(key, text_widget, name_entry):
    if key == keyboard.Key.esc:
    # 当按下esc键时停止监听
    return False
    elif key == keyboard.Key.ctrl_l:
    # 当按下ctrl键时开始截图
    text_widget.insert('1.0', '开始截图\n')
    start_screenshot(text_widget, name_entry)

    def clear_text(text_widget):
    text_widget.delete(1.0, tk.END)

    创建tkinter窗口

    root = tk.Tk()
    root.geometry('145x180')
    text_widget = tk.Text(root, height=10, width=20)
    text_widget.pack()
    name_entry = tk.Entry(root)
    name_entry.pack()
    clear_button = tk.Button(root, text="清空文本框", command=lambda: clear_text(text_widget))
    clear_button.pack()

    开始监听键盘

    with keyboard.Listener(on_release=lambda key: on_release(key, text_widget, name_entry)) as listener:
    root.mainloop()

如有帮助,请多多支持作者! 你鼓励是我最大的动力~QAQ~

相关推荐
PXM的算法星球26 分钟前
【软件工程】面向对象编程(OOP)概念详解
java·python·软件工程
Humbunklung1 小时前
PySide6 GUI 学习笔记——常用类及控件使用方法(常用类矩阵QRectF)
笔记·python·学习·pyqt
蹦蹦跳跳真可爱5891 小时前
Python----深度学习(基于DNN的吃鸡预测)
python·深度学习·dnn
JJ1M82 小时前
Git技巧:Git Hook,自动触发,含实战分享
git·python·自动化
拓端研究室TRL2 小时前
PyMC+AI提示词贝叶斯项目反应IRT理论Rasch分析篮球比赛官方数据:球员能力与位置层级结构研究
大数据·人工智能·python·算法·机器学习
小白用python3 小时前
pycharm无法创建venv虚拟环境
ide·python·pycharm
ImAlex3 小时前
开开心心放假回家,结果忘记老家wifi密码新买的手机连不上WiFi?不用慌,pywifi来拯救你。
python
fantasy_44 小时前
LeetCode238☞除自身以外数组的乘积
java·数据结构·python·算法·leetcode
Tech Synapse4 小时前
零基础搭建AI作曲工具:基于Magenta/TensorFlow的交互式音乐生成系统
人工智能·python·tensorflow
纪元A梦4 小时前
华为OD机试真题——阿里巴巴找黄金宝箱Ⅰ(2025A卷:100分)Java/python/JavaScript/C/C++/GO最佳实现
java·c语言·javascript·c++·python·华为od·go