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~

相关推荐
m0_70203653几秒前
mysql如何通过索引减少行锁范围_mysql索引与加锁逻辑
jvm·数据库·python
用户0332126663674 分钟前
使用 Python 设置 Word 文档文本的颜色
python
qxwlcsdn7 分钟前
如何用 IndexedDB 存储从 API 获取的超大列表并实现二级索引
jvm·数据库·python
小新同学^O^11 分钟前
简单学习 --> 模型微调
开发语言·人工智能·python·模型微淘
2301_8092445327 分钟前
C#怎么使用协变和逆变 C#泛型中的in和out关键字协变逆变是什么意思怎么用【语法】
jvm·数据库·python
知识汲取者36 分钟前
巨量引擎营销 API 完整文档
开发语言·数据库·python
DevnullCoffe40 分钟前
用 MCP 让 AI Agent 直接批量下载亚马逊商品图片——原理、踩坑与实现
爬虫·python·api
时光Autistic1 小时前
【安装教程】AI标注工具X-AnyLabeling安装配置
人工智能·python
knight_9___1 小时前
大模型project面试7
人工智能·python·算法·面试·大模型·agent
yuhuofei20211 小时前
【Python入门】Python与PyCharm的安装
开发语言·python·pycharm