Python利用pynput實現(xiàn)劃詞復制功能
前言
本文參考了以下代碼
Windows系統(tǒng)環(huán)境下Python腳本實現(xiàn)全局“劃詞復制”功能
from pynput import mouse
import time
import threading
__DEBUG = False
def log(msg,debug=False):
if __DEBUG or debug:
print(msg)
class MouseMonitor():
__press_time = 0
__press_double_state = False
__move = (0,0)
def __init__(self,on_selected=None):
if on_selected:
self.on_selected = on_selected
else:
self.on_selected = self.on_selected
self.listener = mouse.Listener(on_move=self.on_move,on_click=self.on_click)
self.listener.start()
self.listener.join()
def on_selected(msg):
print('selected "%s" has been copied.' % (msg,))
def on_move(self,x,y):
if self.__press_time == 0:
self.__move = (x,y)
# log(self.__press_time,time.time())
# log('Pointer moved to {0}'.format((x,y)))
def on_click(self,x,y,button,pressed):
if str(button) == 'Button.left':
if pressed:
self.on_pressed(x,y)
else:
self.on_released(x,y)
def on_pressed(self,x,y):
if self.__press_double_state:
# double click
# self.__press_double_state = False
if not self.check_not_time_out(self.__press_time, time.time(),0.4): # miss double click
log('double1 click timeout and reset then')
self.reset()
self.__press_time = time.time()
else:
# single click
self.__press_time = time.time()
# self.__press_double_state = False
def on_released(self,x,y):
if self.__press_double_state:
# double click
if self.check_not_time_out(self.__press_time, time.time(),0.8):
log('double click: %s' % (self.get_copy()))
self.on_selected(self.get_copy())
self.__press_double_state = False
else:
log('double2 click timeout and reset then')
self.reset()
else:
if self.check_not_time_out(self.__press_time, time.time()):
log('double click maybe')
self.__press_double_state = True
threading.Timer(0.5, self.timeout_handler).start() # wait timeout to reset
elif not self.check_not_time_out(self.__press_time, time.time(),1):
if self.__move != (0,0):
self.on_selected(self.get_copy())
log('selected: %s' % (self.get_copy(),))
self.reset()
else:
log('reset state')
self.reset()
def get_copy(self):
import win32clipboard as wc
import win32con
def trigger_copy():
from pynput.keyboard import Key,Controller
key = Controller()
with key.pressed(Key.ctrl):
key.press('c')
key.release('c')
time.sleep(0.1) # wait for ctrl+c valid
trigger_copy()
msg = ''
try:
wc.OpenClipboard()
msg = wc.GetClipboardData(win32con.CF_UNICODETEXT)
wc.CloseClipboard()
except TypeError:
log('Clipboard Content is TypeError.')
return msg
def reset(self):
self.__press_time = 0
self.__press_double_state = False
self.__move = (0,0)
def timeout_handler(self):
self.reset()
log('timeout reset state')
def check_not_time_out(self,old,new,delta=0.2):
if(new - old > delta): # time delta > 0.2s
return False
else:
return True
def printf(msg):
log('copy content:'+msg,True)
# log('x = {0} , y = {1}'.format(x,y))
if __name__ == '__main__':
mm = MouseMonitor(printf)pynput庫的官方文檔
實現(xiàn)代碼
參考的博客實現(xiàn)了劃詞復制,但是看了下他的代碼寫的有點復制混亂,監(jiān)聽準確率并不高且不太容易理解。
實際監(jiān)聽鼠標的劃詞操作邏輯很簡單:
記錄下鼠標左鍵按下時的位置,當鼠標左鍵松開時,記錄下鼠標左鍵松開的位置,如果按下的位置和松開的位置不一致,說明鼠標正在劃詞。
from pynput.mouse import Listener, Button
from pynput.keyboard import Key, Controller
class AutoCopier():
__press_xy = (0, 0) # 私有變量 鼠標左鍵按下時的位置
def __init__(self):
self.keyboard = Controller() # 初始化鍵盤控制器
self.listener = Listener(on_click=self.on_click) # 初始化鼠標監(jiān)聽器
self.listener.start() # 開啟鼠標監(jiān)聽器線程
# 點擊函數(shù)
def on_click(self, x, y, button, pressed):
if button == Button.left: # 左鍵點擊
if pressed: # 左鍵按下
self.__press_xy = (x, y) # 記錄當前鼠標位置
else: # 左鍵松開
if self.__press_xy != (x, y): # 按下位置和松開位置不一致
self.copy() # 說明操作是劃詞,執(zhí)行復制函數(shù)
# 復制函數(shù)
def copy(self):
with self.keyboard.pressed(Key.ctrl): # 按下ctrl,with語句結(jié)束后自動松開
self.keyboard.press('c') # 按下c
self.keyboard.release('c') # 松開c
# 等待線程終止
def wait_to_stop(self):
self.listener.join()
# for test
if __name__ == '__main__':
at = AutoCopier()
at.wait_to_stop()知識點補充
1.pynput是什么
官方說法:“他可以控制和監(jiān)聽我們的輸入設(shè)備,目前支持鼠標和鍵盤的控制與監(jiān)聽;因為我只使用了設(shè)備的控制 至于監(jiān)聽并沒作深入了解 文章也不設(shè)計”
2.使用步驟
安裝pynput模塊
pip install pynput #使用ctrl+v 快捷粘貼時候用到 pip install pyperclip
鍵盤控制
如下:
from pynput.keyboard import Key, Controller as c_keyboard
from pynput.mouse import Button, Controller as c_mouse
keyboard = c_keyboard()
#字符與數(shù)字
keyboard.press('a')
keyboard.release('a')
keyboard.press('A')
keyboard.release('A')
keyboard.press('1')
keyboard.release('1')
#非數(shù)字與字母鍵 詳情: https://pynput.readthedocs.io/en/latest/keyboard.html#pynput.keyboard.Key
keyboard.press(Key.enter);
keyboard.release(Key.enter);
#組合
##全選
keyboard.press(Key.ctrl)
keyboard.press('a')
time.sleep(2)
keyboard.release('a')
keyboard.release(Key.ctrl)
###或者
with keyboard .pressed(Key.ctrl):
keyboard.press('a')
keyboard.release('a')
##復制
seller_nick = 'www.baidu.com/a.php?a=a&b=2'
pyperclip.copy('https://'+seller_nick.replace('amp;',''))
##粘貼
keyboard.press(Key.ctrl)
keyboard.press('v')
time.sleep(1)
keyboard.release('v')
keyboard.release(Key.ctrl)
##回車
keyboard.press(Key.enter);
keyboard.release(Key.enter);
鼠標控制
如下:
from pynput.keyboard import Key, Controller as c_keyboard from pynput.mouse import Button, Controller as c_mouse mouse= c_mouse() #點擊 ##雙擊 mouse.click(Button.left, 2) ##按下右鍵 mouse.press(Button.right) ##釋放右鍵 mouse.release(Button.right) #鼠標坐標 print(mouse.position) ##x軸坐標 print(mouse.position[0]) ##y軸坐標 print(mouse.position[1]) #移動 ##移動到絕對坐標 mouse.position = (400, 38) ##相對當前坐標移動 mouse.move(300, 2) #滑動 mouse.press(Button.left) mouse.move(300, 2) mouse.release(Button.left)
到此這篇關(guān)于Python利用pynput實現(xiàn)劃詞復制功能的文章就介紹到這了,更多相關(guān)Python pynput劃詞復制內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
PyTorch詳解經(jīng)典網(wǎng)絡(luò)種含并行連結(jié)的網(wǎng)絡(luò)GoogLeNet實現(xiàn)流程
今天小編就為大家分享一篇Pytorch實現(xiàn)GoogLeNet的方法,GoogLeNet提出了一個名為“Inception”的深度卷積神經(jīng)網(wǎng)結(jié)構(gòu),其目標是將分類、識別ILSVRC14數(shù)據(jù)集的技術(shù)水平提高一個層次。這一結(jié)構(gòu)的主要特征是對網(wǎng)絡(luò)內(nèi)部計算資源的利用進行了優(yōu)化2022-05-05
Python數(shù)據(jù)序列化技術(shù)總結(jié)
在現(xiàn)代軟件開發(fā)中,數(shù)據(jù)序列化是一個關(guān)鍵環(huán)節(jié),它允許我們將復雜的數(shù)據(jù)結(jié)構(gòu)轉(zhuǎn)換為可存儲或可傳輸?shù)母袷?,Python提供了多種數(shù)據(jù)序列化技術(shù),每種技術(shù)都有其獨特的性能優(yōu)勢和適用場景,本文將詳細介紹幾種強大的Python數(shù)據(jù)序列化技術(shù),需要的朋友可以參考下2025-03-03
scratch3.0二次開發(fā)之用blocks生成python代碼
python是blockl.generator的一個實例,會調(diào)用generator里的方法,這篇文章主要介紹了scratch3.0二次開發(fā)之用blocks生成python代碼,需要的朋友可以參考下2021-08-08
Python系統(tǒng)監(jiān)控模塊psutil功能與經(jīng)典用法分析
這篇文章主要介紹了Python系統(tǒng)監(jiān)控模塊psutil功能與經(jīng)典用法,簡單講述了psutil模塊的功能、原理并結(jié)合具體實例形式分析了Python使用psutil模塊針對CPU、內(nèi)存、磁盤、網(wǎng)絡(luò)等信息的讀取相關(guān)操作技巧,需要的朋友可以參考下2018-05-05
給Python學習者的文件讀寫指南(含基礎(chǔ)與進階)
今天,貓貓跟大家一起,好好學習Python文件讀寫的內(nèi)容,這部分內(nèi)容特別常用,掌握后對工作和實戰(zhàn)都大有益處,學習是循序漸進的過程,欲速則不達2020-01-01

