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~

相关推荐
丕羽1 小时前
【Pytorch】基本语法
人工智能·pytorch·python
bryant_meng2 小时前
【python】Distribution
开发语言·python·分布函数·常用分布
m0_594526303 小时前
Python批量合并多个PDF
java·python·pdf
工业互联网专业3 小时前
Python毕业设计选题:基于Hadoop的租房数据分析系统的设计与实现
vue.js·hadoop·python·flask·毕业设计·源码·课程设计
钱钱钱端3 小时前
【压力测试】如何确定系统最大并发用户数?
自动化测试·软件测试·python·职场和发展·压力测试·postman
慕卿扬3 小时前
基于python的机器学习(二)—— 使用Scikit-learn库
笔记·python·学习·机器学习·scikit-learn
Json____3 小时前
python的安装环境Miniconda(Conda 命令管理依赖配置)
开发语言·python·conda·miniconda
小袁在上班4 小时前
Python 单元测试中的 Mocking 与 Stubbing:提高测试效率的关键技术
python·单元测试·log4j
白狐欧莱雅4 小时前
使用python中的pygame简单实现飞机大战游戏
经验分享·python·游戏·pygame
阿_旭4 小时前
基于YOLO11/v10/v8/v5深度学习的维修工具检测识别系统设计与实现【python源码+Pyqt5界面+数据集+训练代码】
人工智能·python·深度学习·qt·ai