python之模拟鼠标键盘动作具体实现
发布时间:2022-12-23 10:51:29
上个月就打算开发个还算好玩的项目,但是一直没时间。这篇是此项目用到的一部分,
处理好此部分基本还差通信等方面的了。首先模拟鼠标键盘按下释放的动作,本人利用X11
这个库,所以要了解X11编程;其次,本身用c或者c++就可以实现了,但是由于本人是py
粉,所以总想把代码搬进python,所以本人就要实现python模块,本篇用的ctypes,以后会
把python的c扩展模块附上来的。
1.X11编程
首先简单的介绍一下X11吧,网上有介绍,本人就不重复了。我们知道X是以server与client
的方式提供服务的,我们想要使用其功能,我们就需要与server通信。使用
Display *XOpenDisplay(char *display_name)获得一个Display类型的句柄指针就可以了。
display_name可以是DISPLAY环境变量,用echo $DISPLAY输出是:0(这是本人linux mint输
出的)。如果display_name为NULL接口默认使用环境变量保存的值。X11编程常用的几个头
文件:
#include <X11/Xlib.h>
#include <X11/Xutil.h>
#include <X11/Xos.h>
本人用到的是#include <X11/Xlib.h>和 #include <X11/extensions/XTest.h>.
XTest.h有我们模拟鼠标和键盘需要的接口XTestFakeButtonEvent、 XTestFakeMotionEvent和
XTestFakeKeyEvent。想了解更多信息只需要在终端上man加函数名即可获得。
比如XTestFakeMotionEvent接口:
int XTestFakeMotionEvent(display, screen_number, x, y,delay);
Display *display; //此值就是从XOpenDisplay获得
int screen_number; //让其为-1即可表示当前的屏幕
int x, y; //屏幕位置
unsigned long delay; //延迟毫秒,让其为CurrentTime表示不延迟
最后我们要关闭Display句柄:XCloseDisplay(Display *display)。
接口实现如下:
#include <stdio.h>
#include <X11/extensions/XTest.h>
#include <X11/Xlib.h>
Display *dspopen(){
Display *dsp = XOpenDisplay(NULL);
if(!dsp) {
printf("open display failed\n");
return NULL;
}
return dsp;
}
int presskey(Display *dsp,int s){ //键盘按
if(dsp==NULL)
return -1;
// KeySym keysym=XStringToKeysym(s);
KeyCode key=XKeysymToKeycode(dsp,s);
if(key==NoSymbol)
return -1;
XTestFakeKeyEvent(dsp,key,1,CurrentTime);
XFlush(dsp);
return 0;
}
int move(Display *dsp,int x,int y) //鼠标移动
{
if(0==XTestFakeMotionEvent(dsp,-1,x,y,CurrentTime))
{
printf("Cannot move!\n");
return -1;
}
return 0;
}
int buttonpress(Display *dsp,int type) //鼠标按,type=1表示左键,3是右键,2是中键
{
if(0==XTestFakeButtonEvent(dsp,type,1,CurrentTime))
{
printf("press failed\n");
return -1;
}
return 0;
}
int buttonrelease(Display *dsp,int type) //鼠标释放
{
if(0==XTestFakeButtonEvent(dsp,type,0,CurrentTime))
{
printf("release failed\n");
return -1;
}
return 0;
}
int releasekey(Display *dsp,int s){ //键盘release
if(dsp==NULL)
return -1;
// KeySym keysym=XStringToKeysym(s);
KeyCode key=XKeysymToKeycode(dsp,s);
if(key==NoSymbol)
return -1;
XTestFakeKeyEvent(dsp,key,0,CurrentTime);
XFlush(dsp);
return 0;
}
void dspclose( Display *dsp ){
if(dsp!=NULL){
XCloseDisplay(dsp);
}
}
//int main(){ //测试用的会在程序结束后,在光标前输出c
// Display *dsp=dspopen();
// presskey(dsp,'c');
// releasekey(dsp,'c');
// dspclose(dsp);
// return 0;
//}
上面注释掉的main函数可以作为测试用的,好了,我们把上面的代码保存为display.c
编译成一个共享库,需要X11和Xtst库。
gcc -fPIC -shared -o libdisplay.so display.c -lX11 -lXtst
编译后会生成libdisplay.so 。现在我们ctypes模块使用这个动态共享库。
2.ctypes简单介绍和使用
我们知道python中的类型与c中类型是不一样的,应该说没有一样的,就拿int想来说,
python也是把它看作PyObject类型来处理的。那么我们需要使用ctype提供的接口做类型的
转换。见:http://docs.python.org/2/library/ctypes.html#fundamental-data-types
此链接有张图详细的展现类型转换对应的接口。下面演示具体的操作吧。
我们通过CDLL()接口载入库:
lc=CDLL("./libdisplay.so")
然后就可以使用库中提供的接口了,但是上面dspopen()接口的返回值是Display类型的指针,
所以我们需要用c_void_p()转换一下:
d=c_void_p(lc.dspopen())
之后就可以用d做处理了,代码如下:
from ctypes import *
import time
class MOUSE:
LEFT=1
MiDDLE=2
RIGHT=3
lc=CDLL("./libdisplay.so")
d=c_void_p(lc.dspopen())
time.sleep(5);
lc.buttonpress(d,c_int(MOUSE.RIGHT))
lc.buttonrelease(d,c_int(MOUSE.RIGHT))
lc.dspclose(d)
上面的代码会在5秒后在鼠标指针处打开右键菜单。
利用ctypes使用c编写的库就讲这么多吧。以后会把c代码的部分写成python的c扩展再分享吧。
利用上面的模拟键盘和鼠标的接口可以做一些有意思的事情....
猜你喜欢
- 今天在写一个linux下自动备份指定目录下的所有目录的脚本时,遇到了一个问题,由于我是需要备份目录,所以,需要判断扫描的文件是否为目录,当我
- 代码如下:create table T_NEWS ( ID NUMBER, N_TYPE VARCHAR2(20), N_TIT
- 在上一个文章里写了关于左(右)侧定宽右(左)侧自动缩放的两列浮动,这个文章就要说一下三列浮动的问题了。在之前说过,两列浮动是其他多列浮动的基
- 左右布局,图片的宽度不固定。正好前几天测试闭合浮动元素时发现了overflow的特殊现象,倒是正好可以用在这里。测试通过:ie6/7&nbs
- 本文实例讲述了Golang算法问题之整数拆分实现方法。分享给大家供大家参考,具体如下:一个整数总可以拆分为2的幂的和,例如:7=1+2+47
- 这是一套适用于JavaScript程序的编码规范。它基于Sun的Java程序编码规范。但进行了大幅度的修改, 因为JavaScript不是J
- 我们在日常开发中,我们经常会面对复杂的子系统,其中包含许多相互关联的类和接口。直接使用这些类和接口可能会导致代码的复杂性增加,使得系统难以维
- 一、检测它是不是整数function Is_Int(a_str) if&
- 引言:一开始二维码加群,但是呢,这个东西隔一段时间会过期,我需要 每隔一段时间去更新二维码,然后当群人数超过100人了,只能邀请进群, 这个
- 我是一个初入互联网的视觉设计师,和以往做设计感受最大的不同就是:一个设计的最终定稿会受到多方面的挑战,有来自产品经理的,来自开发的,来自测试
- js 对url进行编码和解码三种编码和解码函数encodeURI和 decodeURI它着眼于对整个URL进行编码,因此除了常见的符号以外,
- 1.cURL介绍 cURL 是一个利用URL语法规定来传输文件和数据的工具,支持很多协议,如HTTP、FTP、TELNET等。最爽的是,PH
- 浏览器经常Cache你的页面,这是一个很麻烦的问题,下面先提出几种方案来解决一般的问题:(把下面的代码加入到asp程序的最开始位置)<
- 虽然每个图像具有多个通道和多层卷积层。例如彩 * 像具有标准的RGB通道来指示红、绿和蓝。但是到目前为止,我们仅展示了单个输入和单个输出通道的
- 北京邮电大学 张剑XML的局限性目前,许多Web网站的内容数据都存放在数据库或数据文件中。对于Web程序开发人员来说,如果要想把有用的信息从
- 本文实例讲述了kNN算法python实现和简单数字识别的方法。分享给大家供大家参考。具体如下:kNN算法算法优缺点:优点:精度高、对异常值不
- 这里的内容以Linux进程基础和Linux文本流为基础。subprocess包主要功能是执行外部的命令和程序。比如说,我需要使用wget下载
- #BEGIN CONFIG INFO#DESCR: 4GB RAM, 只使用InnoDB, ACID, 少量的连接, 队列负载大#TYPE:
- CSS浮动一直是个比较让人郁闷的问题,很多的布局问题都出在浮动上,特别是当浮动的列数很多时,但其实只要理解了两列结构的浮动,面对多列数的浮动
- Laravel通过传统的登录表单已经让用户认证变得很简单,但是API怎么办?API通常使用token进行认证并且在请求之间不维护sessio