开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 2035|回复: 0
收起左侧

[JS相关教程] js windows窗口元素定位方法

[复制链接]
结帖率:0% (0/1)
发表于 2021-5-22 14:43:29 | 显示全部楼层 |阅读模式   江西省景德镇市
什么是Ai-Bot?
Ai-Bot是Android+Windows平台上的node.js自动化框架。

1、跟python的区别?跟uipaht uibot 其他框架的区别?
1) VS python
相同点:Ai-Bot基于node.js语言的一款自动化框架。和python一样,有同样强大的社区库调用。

不同点:
           1、Ai-Bot内置chromium内核浏览器,绕过webdriver驱动直接与浏览器内核通信。python selenium则通过webdriver驱动浏览器,浏览器会有webdriver特征码。
           2、Ai-Bot 支持windows ui元素操作,Id、Name、className、ControlType、XPath等定位方式。c++实现速度非常快。
           3、Android自动化,优化appium内核,动态画面处理较快,除了appium 提供元素定位之外,还支持文字定位、图色定位,有效提供h5 webview界面的自动化需求。

2) VS uipaht uibot
          1、uipaht uibot 图形编辑机器人,相对于Ai-Bot低代码形式,更适合普通人使用。
          2、Ai-Bot 采用c++实现,与目前其他rpa框架 c# vb python等语言实现不同。对于专业的rpa实施人士来说,Ai-Bot灵活性更高,机器人运行更稳定性强,速度更快。
          3、由于Ai-Bot拥有node.js强大社区库,它能够完成其他rpa框架无法完成的工作需求。
          4、Ai-Bot 不依赖系统的软件环境。直接对word excle 数据库和浏览器操作,电脑上不需安装相关软件。
          5、Ai-Bot 支持Android和windows 平台同时协作办公
          6、Ai-Bot 大部分功能是开源的。

2、Ai-Bot开发文档
1)Windows开发文档

1.创建/关闭WindowsBot
(1)主函数示例
const windowsBot = require('WindowsBot');//引用WindowsBot模块
async function mian()
{
let windowsBotPort = 9999;
let proxyServer = "127.0.0.1:888";
//初始化WindowsBot
await windowsBot.InitWindowsBot(windowsBotPort, proxyServer);
}
mian();
//主函数初始化WindowsBot服务
//windowsBotPort 整型,WindowsBot服务端口,多开进程,端口不可重复
//proxyServer 字符串,可选参数。设置WebBot内置浏览器代理ip
(2)关闭WindowsBot
await CloseWindowsBot();
//关闭WindowsBot服务
2.等待超时
await windowsBot.Sleep(3000);
//显示等待
//参数一 整型,等待时间,单位毫秒
await windowsBot.SetImplicitTimeout(waitMS, intervalMS = 10);
//隐式等待
//参数一 整型,等待时间,单位毫秒
//参数二 整型,心跳间隔,单位毫秒。可选参数,默认10毫秒
3.操作模式
await windowsBot.SetCurMode(true);
//参数一 布尔类型,true前台,false后台,WindowsBot默认前台操作
4.查找窗口句柄
await windowsBot.FindWindowHandle("className", "windowName");
//查找窗口句柄
//参数一 字符串型,窗口类名
//参数二 字符串型,窗口标题
//成功返回句柄,失败返回null
await windowsBot.FindWindowsHandle("className", "windowName");
//查找窗口句柄数组
//参数一 字符串型,窗口类名
//参数二 字符串型,窗口标题
//成功返回句柄数组,失败返回null
await windowsBot.FindSubWindowHandle("hwndParent", "className", "windowName");
//查找子窗口句柄
//参数一 整型,父窗口句柄
//参数二 字符串型,窗口类名
//参数三 字符串型,窗口标题
//成功返回句柄,失败返回null
await windowsBot.FindWebBotHandle();
//查找WebBot内置浏览器句柄
//成功返回句柄,失败返回null
5.鼠标操作
await windowsBot.MoveMouse(hwnd, x, y);
//移动鼠标
//参数一 整型,窗口句柄
//参数二 整型,x坐标
//参数三 整型,y坐标
await windowsBot.RollMouse(hwnd, x, y, dwData);
//滚动鼠标
//参数一 整型,窗口句柄
//参数二 整型,x坐标
//参数三 整型,y坐标
//参数四 整型,鼠标滚动次数,负数下滚鼠标,正数上滚鼠标
await windowsBot.ClickMouse(hwnd, x, y, msg);
//点击鼠标,后台模式下,控件独句柄与hwnd不一致时会失败
//参数一 整型,窗口句柄
//参数二 整型,x坐标
//参数三 整型,y坐标
//参数四,单击左键:1 单击右键:2 按下左键:3 弹起左键:4 按下右键:5 弹起右键:6 双击左键:7 双击右键:8
6.键盘操作
await windowsBot.InputText(hwnd, text);
//输入文本,杀毒软件可能会拦截
//参数一 整型,窗口句柄
//参数二 字符串型,输入内容
await windowsBot.InputKeyborad(bVk, msg);
//输入键盘VK值
//参数一 整型,VK键值
//参数二 整型,按下弹起:1 按下:2 弹起:3
7.截图保存
await windowsBot.SaveScreenshot(hwnd, imagePath, x = 0, y =0, width = 0, height = 0);
//后台截图保存
//参数一 整型,窗口句柄
//参数二 字符串型,图片保存的路径
//参数三 整型,可选参数,顶点x坐标
//参数四 整型,可选参数,顶点y坐标
//参数五 整型,可选参数,图片宽度
//参数六 整型,可选参数,图片高度
//成功返回true,失败返回false
await windowsBot.FrontSaveScreenshot(imagePath, x = 0, y =0, width = 0, height = 0);
//前台截图保存,当SaveScreenshot截图失效时,可用此函数
//参数一 字符串型,图片保存的路径
//参数二 整型,可选参数,顶点x坐标
//参数三 整型,可选参数,顶点y坐标
//参数四 整型,可选参数,图片宽度
//参数五 整型,可选参数,图片高度
//成功返回true,失败返回false
8.图色定位
await windowsBot.FindColorCount(imagePath, R, G, B);
//查找图片颜色点的数量和坐标
//参数一 字符串型,图片的路径
//参数二 整型,红
//参数三 整型,绿
//参数四 整型,蓝
//返回指定rgb点的数量和坐标
await windowsBot.FindColor(hwnd, imagePath, R, G, B, index = 0);
//查找指定色值在图片上的位置
//参数一 整型,窗口句柄
//参数二 字符串型,图片的路径
//参数三 整型,红
//参数四 整型,绿
//参数五 整型,蓝
//参数六 整型,可选参数,指定出现的次数,默认第一次查找到的坐标
//成功返回指定rgb点的坐标,失败返回 {x:-1, y:-1}
await windowsBot.FindImage(hwnd, sourceImagePath, destImagePath, sim);
//查找图片,大图找小图
//参数一 整型,窗口句柄
//参数二 字符串型,大图路径
//参数三 字符串型,小图路径
//参数四 浮点型,相似度0.0-1.0
//成功返回指定rgb点的坐标,失败返回 {x:-1, y:-1}
9.系统剪切板
await windowsBot.SetClipboardText(text);
//设置剪切板文本
//参数一 字符串型,设置的文本
await windowsBot.GetClipboardText();
//获取剪切板文本
//返回剪切板文本
10.启动程序
await windowsBot.StartProcess(commandLine, showWindow = true, isWait = false);
//启动指定程序
//参数一 字符串型,启动命令行
//参数二 布尔型,是否显示窗口。可选参数,默认显示窗口
//参数三 布尔型,是否等待程序结束。可选参数,默认不等待
//成功返回true,失败返回false
11.下载文件
await windowsBot.DownloadFile(url, filePath, isWait);
//启动指定程序
//参数一 字符串型,文件地址
//参数二 字符串型,文件保存的路径
//参数三 布尔型,是否等待.为true时,等待下载完成
12.ocr系统
await windowsBot.InitOcr(appId, apiKey, secretKey);
//初始化百度ocr
//参数一 字符串型,百度ocr提供
//参数二 字符串型,百度ocr提供
//参数三 字符串型,百度ocr提供
await windowsBot.GetImageWords(imagePath, ocrType);
//百度ocr获取图片上的文字
//参数一 字符串型,图片路径
//参数二 整型,识别类型,通用文字识别:1 高精度版:2 网络图片文字识别:3 数字识别:4 手写文字识
别:5 二维码识别:6
//成功返回获取的文字
await windowsBot.FindImageWords(hwnd, imagePath, words, index = 0);
//百度ocr获取图片文字坐标
//参数一 整型,图片所属窗口的句柄,手机图片识别一般为null
//参数二 字符串型,图片路径
//参数三 字符串型,识别的文字
//参数四 整型,可选参数。文字出现的次数,默认为0,查找第一次出现的坐标
//成功返回文字坐标,失败返回{x:-1, y:-1}
13.验证码识别系统
await windowsBot.InitCheckCode(userName, passWord);
//初始化验证码系统
//参数一 字符串型,用户名,第三方平台提供
//参数二 字符串型,用户密码,第三方平台提供
await windowsBot.GetCheckCode(imagePath, codeType);
//获取验证码
//参数一 字符串型,验证码图片路径
//参数二 字符串型,验证码类型,参考第三方平台
//成功返回验证码,失败返回错误信息
await windowsBot.SendErrorCode();
//发送验证码识出错
//成功返回"true",失败返回错误信息
14.窗口元素操作
注意:窗口元素操作未默认释放,必须手动释放,否则内存泄漏!
(1)查找元素
await windowsBot.FindRootElement(hwnd);
//查找窗口根元素
//参数一 整型,窗口句柄
//成功返回元素对象,失败返回null
await windowsBot.FindFocusElement();
//查找焦点元素
//成功返回元素对象,失败返回null
await windowsBot.FindElementByAutomationId(rootElement, automationId);
//通过automationId查找元素
//参数一 对象,根元素
//参数二 字符串,要查找元素的automationId值
//成功返回元素对象,失败返回null
await windowsBot.FindElementsByAutomationId(rootElement, automationId);
//通过automationId查找元素数组
//参数一 对象,根元素
//参数二 字符串,要查找元素的automationId值
//成功返回元素对象数组,失败返回null
await windowsBot.FindElementByName(rootElement, name);
//通过name查找元素
//参数一 对象,根元素
//参数二 字符串,要查找元素的name值
//成功返回元素对象,失败返回null
await windowsBot.FindElementsByName(rootElement, name);
//通过name查找元素数组
//参数一 对象,根元素
//参数二 字符串,要查找元素的name值
//成功返回元素对象数组,失败返回null
await windowsBot.FindElementByClassName(rootElement, className);
//通过className查找元素
//参数一 对象,根元素
//参数二 字符串,要查找元素的className值
//成功返回元素对象,失败返回null
await windowsBot.FindElementsByClassName(rootElement, className);
//通过className查找元素数组
//参数一 对象,根元素
//参数二 字符串,要查找元素的className值
//成功返回元素对象数组,失败返回null
await windowsBot.FindElementByControlType(rootElement, controlType);
//通过controlType查找元素
//参数一 对象,根元素
//参数二 字符串,要查找元素的controlType值
//成功返回元素对象,失败返回null
await windowsBot.FindElementsByControlType(rootElement, controlType);
//通过controlType查找元素数组
//参数一 对象,根元素
//参数二 字符串,要查找元素的controlType值
//成功返回元素对象数组,失败返回null
await windowsBot.FindElementByXpath(rootElement, xpath);
//通过xpath查找元素
//参数一 对象,根元素
//参数二 字符串,要查找元素的xpath值
//成功返回元素对象,失败返回null
await windowsBot.FindParentElement(currentElement, isRelease = true);
//查找父元素
//参数一 对象,当前元素
//参数二 布尔型,可选参数。是否释放当前元素
//currentElement不再使用时必须释放,否则内存泄漏.默认为true释放当前元素
//成功返回元素对象,失败返回null
await windowsBot.FindNextSiblingElement(currentElement, isRelease = true);
//查找下一个兄弟元素
//参数一 对象,当前元素
//参数二 布尔型,可选参数。是否释放当前元素
//currentElement不再使用时必须释放,否则内存泄漏.默认为true释放当前元素
//成功返回元素对象,失败返回null
await windowsBot.FindPreviousSiblingElement(currentElement, isRelease = true);
//查找上一个兄弟元素
//参数一 对象,当前元素
//参数二 布尔型,可选参数。是否释放当前元素
//currentElement不再使用时必须释放,否则内存泄漏.默认为true释放当前元素
//成功返回元素对象,失败返回null
await windowsBot.FindFirstChildElement(currentElement, isRelease = true);
//查找第一个子元素
//参数一 对象,当前元素
//参数二 布尔型,可选参数。是否释放当前元素
//currentElement不再使用时必须释放,否则内存泄漏.默认为true释放当前元素
//成功返回元素对象,失败返回null
await windowsBot.FindLastChildElement(currentElement, isRelease = true);
//查找最后一个子元素
//参数一 对象,当前元素
//参数二 布尔型,可选参数。是否释放当前元素
//currentElement不再使用时必须释放,否则内存泄漏.默认为true释放当前元素
//成功返回元素对象,失败返回null
(2)元素方法
await windowsBot.GetElementName(element, isRelease = true);
//获取指定元素name属性值
//参数一 对象,指定元素
//参数二 布尔型,可选参数。element不再使用时必须释放,否则内存泄漏.默认为true释放
//成功返回元素name属性值
await windowsBot.GetElementBoundingRectangle(element, isRelease = true);
//获取指定元素矩形大小
//参数一 对象,指定元素
//参数二 布尔型,可选参数。element不再使用时必须释放,否则内存泄漏.默认为true释放
//成功返回元素矩形大小,失败返回{left:-1, top:-1, right:-1, bottom:-1}
await windowsBot.GetElementValueValue(element, isRelease = true);
//获取指定元素ValueValue属性值
//参数一 对象,指定元素
//参数二 布尔型,可选参数。element不再使用时必须释放,否则内存泄漏.默认为true释放
//成功返回元素ValueValue属性值
await windowsBot.GetControlType(element, isRelease = true);
//获取指定元素ControlType属性值
//参数一 对象,指定元素
//参数二 布尔型,可选参数。element不再使用时必须释放,否则内存泄漏.默认为true释放
//成功返回元素ControlType属性值
await windowsBot.SetElementValue(element, value, isRelease = true);
//设置指定元素value
//参数一 对象,指定元素
//参数二 字符串型,设置的值
//参数三 布尔型,可选参数。element不再使用时必须释放,否则内存泄漏.默认为true释放
//成功返回true,失败返回false
await windowsBot.SetElementValueEx(element, value, isRelease = true);
//通过元素窗口句柄设置指定元素value
//参数一 对象,指定元素
//参数二 字符串型,设置的值
//参数三 布尔型,可选参数。element不再使用时必须释放,否则内存泄漏.默认为true释放
//成功返回true,失败返回false.后台模式下,如果元素没有句柄则失败
await windowsBot.InvokeElement(element, isRelease = true);
//执行元素默认操作,一般用作点击
//参数一 对象,指定元素
//参数二 布尔型,可选参数。element不再使用时必须释放,否则内存泄漏.默认为true释放
//成功返回true,失败返回false
await windowsBot.SetElementFocus(element, isRelease = true);
//设置指定元素作为焦点
//参数一 对象,指定元素
//参数二 布尔型,可选参数。element不再使用时必须释放,否则内存泄漏.默认为true释放
//成功返回true,失败返回false
await windowsBot.SetElementScroll(element, horizontalPercent, verticalPercent, isRelease = true);
//设置指定元素滚动条
//参数一 对象,指定元素
//参数二 浮点型,水平百分比0.0-1.0,为-1时不滚动
//参数三 浮点型,垂直百分比0.0-1.0,为-1时不滚动
//参数四 布尔型,可选参数。element不再使用时必须释放,否则内存泄漏.默认为true释放
//成功返回true,失败返回false
await windowsBot.ClickElement(element, msg, isRelease = true);
//通过元素窗口句柄点击控件
//参数一 对象,指定元素
//参数二 整型,单击左键:1 单击右键:2 按下左键:3 弹起左键:4 按下右键:5 弹起右键:6 双击左键:7
双击右键:8
//参数三 布尔型,可选参数。element不再使用时必须释放,否则内存泄漏.默认为true释放
//成功返回true,失败返回false.后台模式下,元素没有句柄则失败
await windowsBot.CloseWindow(element, isRelease = true);
//关闭指定元素窗口
//参数一 对象,指定元素
//参数二 布尔型,可选参数。element不再使用时必须释放,否则内存泄漏.默认为true释放
//成功返回true,失败返回false.
await windowsBot.SetWindowState(element, state, isRelease = true);
//设置指定元素窗口状态
//参数一 对象,指定元素
//参数二 整型,正常:0 最大化:1 最小化:2
//参数三 布尔型,可选参数。element不再使用时必须释放,否则内存泄漏.默认为true释放
//成功返回true,失败返回false.
await windowsBot.ReleaseElement(element);
//手动释放指定元素,windows元素操作必须要释放元素,否则内存泄漏
//参数一 对象,指定元素
//成功返回true,失败返回false.
await windowsBot.ReleaseElements(elements);
//手动释放指定元素数组,元素数组不再使用时,必须调用此函数手动释放,否则大量内存泄漏
//参数一 对象,指定元素数组
15.内置浏览器(WebBot)
(1)WebBot操作
await windowsBot.openWebBot(url);
//打开内置浏览器WebBot
//参数一 字符串型,指定网址
await windowsBot.switchPage(index);
//切换WebBot页面
//参数一 整型,索引号,0为起首页
await windowsBot.closePage(index);
//关闭WebBot页面
//参数一 整型,索引号,0为起首页
(2)获取元素
await windowsBot.getElementById(id, iframe = null);
//通过id获取元素
//参数一 字符串型,元素id值
//参数二 字符串型,可选参数,元素所属的iframe
//成功返回元素对象,失败返回null
await windowsBot.getElementsByClassName(classNames, iframe = null);
//通过class获取元素数组
//参数一 字符串型,元素class值
//参数二 字符串型,可选参数,元素所属的iframe
//成功返回元素对象数组,失败返回null
await windowsBot.getElementsByName(elementName, iframe = null);
//通过name获取元素数组
//参数一 字符串型,元素name值
//参数二 字符串型,可选参数,元素所属的iframe
//成功返回元素对象数组,失败返回null
await windowsBot.getElementsByTagName(localName, iframe = null);
//通过tagName获取元素数组
//参数一 字符串型,元素tagName值
//参数二 字符串型,可选参数,元素所属的iframe
//成功返回元素对象数组,失败返回null
await windowsBot.getElementByXpath(xpath, iframe = null);
//通过xpath获取元素数组
//参数一 字符串型,元素xpath路径
//参数二 字符串型,可选参数,元素所属的iframe
//成功返回元素对象,失败返回null
await windowsBot.querySelector(selector, iframe = null);
//通过ccs selector获取元素
//参数一 字符串型,元素selector路径
//参数二 字符串型,可选参数,元素所属的iframe
//成功返回元素对象,失败返回null
await windowsBot.querySelectorAll(selectors, iframe = null);
//通过ccs selector获取元素数组
//参数一 字符串型,元素selector路径
//参数二 字符串型,可选参数,元素所属的iframe
//成功返回元素对象数组,失败返回null
(3)元素方法
await windowsBot.clickElement(element);
//点击元素
//参数一 对象,要点击的元素
await windowsBot.clickElementEx(element);
//点击元素(windows api方式点击)
//参数一 对象,要点击的元素
await windowsBot.setValue(element, value);
//设置元素value
//参数一 对象,设置的元素
//参数二 字符串型,设置的值
await windowsBot.getValue(element);
//获取元素value
//参数一 对象,指定的元素
//成功返回value值
await windowsBot.setTextConten(element, value);
//设置元素textConten
//参数一 对象,设置的元素
//参数二 字符串型,设置的值
await windowsBot.getTextConten(element);
//获取元素textConten
//参数一 对象,指定的元素
//成功返回textConten值
await windowsBot.setOuterText(element, value);
//设置元素outerText
//参数一 对象,设置的元素
//参数二 字符串型,设置的值
await windowsBot.getOuterText(element);
//获取元素outerText
//参数一 对象,指定的元素
//成功返回outerText值
await windowsBot.setOuterHTML(element, value);
//设置元素setOuterHTML
//参数一 对象,设置的元素
//参数二 字符串型,设置的值
await windowsBot.getOuterHTML(element);
//获取元素outerText
//参数一 对象,指定的元素
//成功返回outerHTML值
await windowsBot.setInnerText(element, value);
//设置元素setInnerText
//参数一 对象,设置的元素
//参数二 字符串型,设置的值
await windowsBot.getInnerText(element);
//获取元素innerHTML
//参数一 对象,指定的元素
//成功返回innerHTML值
await windowsBot.setAttribute(element, value, name);
//设置元素属性
//参数一 对象,设置的元素
//参数二 字符串型,设置的值
//参数三 字符串型,属性名称
await windowsBot.getAttribute(element, name);
//获取元素属性值
//参数一 对象,指定的元素
//参数二 字符串型,属性名称
//成功返回name对应的属性值
await windowsBot.setSelect(element, checkValue);
//选择下拉框值
//参数一 对象,指定的元素
//参数二 字符串型,选中的值
//成功返回name对应的属性值
await windowsBot.getBoundingClientRect(element);
//获取元素矩形大小
//参数一 对象,指定的元素
//成功返矩形大小,失败返回null
(4)注入JavaScript
await windowsBot.executeScript(scriptCode);
//注入JavaScript代码在v8执行
//参数一 字符串型,JavaScript代码
(5)node与V8数据共享
await windowsBot.nodePipeScript(shareData = 'null');
//WebBot V8有同名称扩展函数,可在executeScript调用。shareData更新需要10-100毫秒
//参数一 字符串型,设置共享数据值,可选参数。
//返回node/v8 设置的shareData值。
16.Word文档
await windowsBot.wordCreate(options = {type: 'docx'});
/创建Wrod文档
//参数一 对象,Word文档格式,可选参数,options列表:
* type(字符串)'docx' 必要参数值
* author(字符串)-文档的作者
* creator(字符串)-别名。文档的作者
* description'(字符串)-文档的属性注释
* keywords(字符串)-文档的关键字
* orientation(字符串)-横向'landscape'或纵向'portrait'。默认值为'portrait'
* pageMargins(对象)-设置文档页边距。默认值为{top: 1800, right: 1440, bottom: 1800,
left: 1440}
* pageSize(字符串|对象)-设置文档页面大小。默认值为A4(支持值:'A4', 'A3', 'letter
paper')。或使用{width: 11906, height: 16838}设置自定义尺寸
* subject (字符串)-文档的主题
* title(字符串)-文档的标题
* columns(整型)-每页中的列数。默认值为1列。
//返回word对象
await windowsBot.wordAddPage(docxObject);
//添加word分页
//参数一 对象,word对象
await windowsBot.wordCreateTable(docxObject, table, tableStyle);
//创建word表格
//参数一 对象,word对象
//参数二 对象,表格
//参数三 对象,表格样式
await windowsBot.wordAddHeader(docxObject, text, options = '');
//添加页眉
//参数一 对象,word对象
//参数二 字符串,要添加的文本
//参数三 字符串,可选参数,要更改的页面 'even'更改偶数页。'first'仅更改首页
await windowsBot.wordAddFooter(docxObject, text, options = '');
//添加页脚
//参数一 对象,word对象
//参数二 字符串,要添加的文本
//参数三 字符串,可选参数,要更改的页面 'even'更改偶数页。'first'仅更改首页
await windowsBot.wordCreateParagraph(docxObject, options = {align: 'left'});
//创建段落
//参数一 对象,word对象
//参数二 对象, 可选参数,段落格式,options列表:
* align(字符串)-水平对齐,可以是'left'(默认),'right','center'或'justify'
* textAlignment(字符串)-垂直对齐方式,'center', 'top', 'bottom'或'baseline'
* indentLeft(数字)- 向左缩进
* indentFirstLine(数字)- 缩进第一行
* backline(字符串)-颜色代码,例如:'ffffff'(白色)或'000000'黑色)
//成功返回段落对象
await windowsBot.wordCreateListOfDots(docxObject, options = {align: 'left'});
//创建无作序号的段落
//参数一 对象,word对象
//参数二 对象, 可选参数,段落格式,options列表:参考wordCreateParagraph
//成功返回段落对象
await windowsBot.wordCreateListOfNumbers(docxObject, options = {align: 'left'});
//创建有序号数字的段落
//参数一 对象,word对象
//参数二 对象, 可选参数,段落格式,options列表:参考wordCreateParagraph
//成功返回段落对象
await windowsBot.wordCreateNestedUnOrderedList(docxObject, options = {"level":2});
//创建有等级的无序号段落
//参数一 对象,word对象
//参数二 对象, 可选参数,段落格式,options列表:参考wordCreateParagraph
//成功返回段落对象
await windowsBot.wordCreateNestedOrderedList(docxObject, options = {"level":2});
//创建有等级的序号段落
//参数一 对象,word对象
//参数二 对象, 可选参数,段落格式,options列表:参考wordCreateParagraph
//成功返回段落对象
await windowsBot.wordAddText(paragraphObject, text, sytle = {});
//将文本添加到段落
//参数一 对象,段落对象对象
//参数二 字符串, 要添加的文本
//参数三 对象,可选参数,文本样式,sytle列表:
* back(字符串)-背景颜色代码,例如:'ffffff'(白色)或'000000'黑色)
* shdType(字符串)-要使用的可选模式代码:'clear'(无模
式),'pct10','pct12','pct15','diagCross','diagStripe','horzCross','horzStripe','
nil' ,'thinDiagCross','solid'等
* shdColor(字符串)-模式的前部颜色(与shdType一起使用)
* bold(布尔)-为true时文本变为粗体
* border(字符串)-边框类
型:'single','dashDotStroked','dashed','dashSmallGap','dotDash','dotDotDash','dott
ed','double','thick'
* color(字符串)-字体颜色代码,例如:“ ffffff”(白色)或“ 000000”(黑色)
* italic(布尔值)-设置为斜体时为true
* underline(布尔值)-为true表示要添加下划线
* font_face(字符串)-要使用的字体,例如:'Arial'
* font_face_east(字符串)-高级设置:用于东亚的字体。您还必须设置font_face
* font_face_cs(字符串)-高级设置:要使用的字体(cs)。您还必须设置font_face
* font_face_h(字符串)-高级设置:要使用的字体(hAnsi)。您还必须设置font_face
* font_hint(字符串)-可选。'ascii'(默认),'eastAsia','cs'或'hAnsi'
* font_size(数字)-以磅为单位的字体大小
* rtl(布尔值)-将其添加到rtl语言的任何文本中
* highlight (字符串) - 高亮颜色。'black', 'blue', 'cyan', 'darkBlue', 'darkCyan',
'darkGray', 'darkGreen', 'darkMagenta', 'darkRed', 'darkYellow', 'green', 'lightGray',
'magenta', 'none', 'red', 'white','yellow'
* strikethrough(布尔值)-添加删除线时为true。
* superscript(布尔值)-如果可以使用较小的尺寸,则为true可以将此次运行中的文本降低到基
线以下,并将其更改为较小的尺寸。
* subscript(布尔值)-为true时,如果可以使用较小的尺寸,则将运行中的文本升高到基线以
上,并将其更改为较小的尺寸
* link(字符串)-超连接
* hyperlink(字符串)向书签的超链接
await windowsBot.wordAddImage(paragraphObject, imagePath, area = {});
//将图像添加到段落
//参数一 对象,段落对象
//参数二 字符串, 图片路径
//参数三 对象, 可选参数, 图片宽高 {cx: 300, cy: 200}
await windowsBot.wordBreak(paragraphObject);
//段落换行
//参数一 对象,段落对象
await windowsBot.wordAddHorizontalLine(paragraphObject);
//添加一条水平线,看上去与换行相似?
//参数一 对象,段落对象
await windowsBot.wordStartBookmark(paragraphObject, markName);
//添加书签
//参数一 对象,段落对象
//参数二 字符串,标签名
await windowsBot.wordEndBookmark(paragraphObject);
//书签结束位置
//参数一 对象,段落对象
await windowsBot.wordSave(docxObject, filePath);
//保存word文件
//参数一 对象,word对象
//参数二 字符串,保存的路径
await windowsBot.wordReadText(filePath);
//读取word内容
//参数一 字符串,保存的路径
//成功返回读取到的内容,失败返回null
17.Excel文档
await windowsBot.OpenExcel(excelPath);
//打开excel文档
//参数一 字符串,excle路径
//成功返回excel对象,失败返回null
await windowsBot.OpenExcelSheet(excelObject, sheetName);
//打开excel表格
//参数一 对象,excel对象
//参数二 字符串,表名
//成功返回sheet对象,失败返回null
await windowsBot.SaveExcel(excelObject);
//保存excel文档
//参数一 对象,excel对象
//成功返回true,失败返回false
await windowsBot.WriteExcelNum(sheetObject, row, col, value);
//写入数字到excel表格
//参数一 对象,sheet对象
//参数二 整型,行
//参数三 整型,列
//参数四 数字型,写入的值
//成功返回true,失败返回false
await windowsBot.WriteExcelStr(sheetObject, row, col, strValue);
//写入字串到excel表格
//参数一 对象,sheet对象
//参数二 整型,行
//参数三 整型,列
//参数四 字符串,写入的值
//成功返回true,失败返回false
await windowsBot.ReadExcelNum(sheetObject, row, col);
//读取excel表格数字
//参数一 对象,sheet对象
//参数二 整型,行
//参数三 整型,列
//返回读取到的数字
await windowsBot.ReadExcelStr(sheetObject, row, col);
//读取excel表格字串
//参数一 对象,sheet对象
//参数二 整型,行
//参数三 整型,列
//返回读取到的字符
18.邮件收发
await windowsBot.SendMail(smtpServer, smtpPort, authCode, sendMailer, sendName, recvMailer,
subject, text, html = null, attachments = null);
//发送邮件
//参数一 字符串,SMTP服务地址
//参数二 整型,SMTP服务端号
//参数三 字符串,第三方邮箱平台授权码
//参数四 字符串,发送人邮箱
//参数五 字符串,发送人名称
//参数六 字符串,接收人邮箱,多人逗号分开
//参数七 字符串,邮箱主题
//参数八 字符串,发送的正文 文本格式
//参数九 字符串,发送的正文 html格式,可选参数,默认为null
//参数十 字符串, 发送的附件,可选参数,默认为null 示例:
let attachments = [
{ // utf-8字符串作为附件
filename: 'text1.txt',
content: 'hello world!'
},
{ //磁盘上的文件作为附件
filename: 'text3.txt',
path: '/path/to/file.txt'
},
{ //文件名和内容类型是从路径生成
path: '/path/to/file.txt'
},
{ //使用URL作为附件
filename: 'WindowsDoc.pdf',
path: 'http://www.ai-bot.net/WindowsDoc.pdf'
}
]
//成功返回"邮件发送成功!",失败返回错误信息
await windowsBot.GetMail(imapServer, imapPort, authCode, mailAccount,criteria);
//获取邮件
//参数一 字符串,IMAP服务地址
//参数二 整型,IMAP服务端号
//参数三 字符串,第三方邮箱平台授权码
//参数四 字符串,邮箱账号
//参数五 字符串,获取哪类邮件,所有邮件'ALL' 未读邮件'UNSEEN' 已读邮件'SEEN' 第1-3封'1:3'
//成功返回邮件信息对象,失败返回错误信息



2)Android开发文档

1.创建/删除AndroidBot
(1)主函数示例
const androidBot = require('AndroidBot');//引用AndroidBot模块
async function mian()
{
let devicesId = "da32u4";
let serverPort = 4723;
let package = "com.example";
let activity = "activityName";
let version = "10";
//初始化AndroidBot
var driver = await androidBot.InitAndroidBot(devicesId, serverPort, package, activity, version);
}
mian();
//AndroidBot主函数调用InitAndroidBot初始化。返回值driver调用其他函数,必须使用await关键字
//devicesId 字符串,设备ID,Ai-Bot工具 安卓——设备列表 选项获取
//serverPort 整型,服务端口,多进程端口必须间隔1,比如 4723、4725、4727
//package 字符串,应用程序包名,Ai-Bot工具 安卓——查看包名 选项获取
//activity 字符串,应用程序活动窗口名,Ai-Bot工具 安卓——查看包名 选项获取
//version 字符串,安卓系统版本号
//成功返回AndroidBot对象
(2)获取/设置参数
await driver.capabilities;
//获取启动参数
await driver.getSettings();
//获取设定值
await driver.updateSettings({ignoreUnimportantViews: true});
//更改设定值,例如ignoreUnimportantViews: true 忽略其他不相关元素
(3)删除会话
await driver.deleteSession();
//删除driver对象
2.超时设置
await driver.setTimeouts(5000);
//设置超时 5秒
await driver.setImplicitTimeout(5000);
//设置隐式等待超时,脚本在搜索元素时等待的时间,默认隐式等待为0ms
await driver.setAsyncTimeout(5000);
//设置允许由 executeAsync 执行的异步脚本的等待超时(以毫秒为单位)
3.屏幕操作
await driver.getOrientation();
//获取当前设备横竖屏状态。
//返回值 字符串 LANDSCAPE(横屏) PORTRAIT(竖屏)
await driver.setOrientation("LANDSCAPE");
//设置横竖屏,LANDSCAPE(横屏) PORTRAIT(竖屏)
await driver.startRecordingScreen();
//开始录制屏幕
await driver.stopRecordingScreen();
//停止录制屏幕;
//返回值:Base64 编码的字符串
await driver.lock();
//锁定设备
await driver.unlock();
//解锁设备
await driver.isLocked();
//判断设备是否被锁定,如果设备已锁定,返回True,否则为false
await driver.rotateDevice(100, 100);
//三维旋转设备
await driver.shake();
//摇动设备
4.获取系统状态
await driver.getPerformanceDataTypes();
//返回允许读取的系统状态的信息类型,例如cpu,内存,网络流量和电池
await driver.getPerformanceData('my.app.package', 'cpuinfo', 5);
//参数1,应用程序的软件包名称
//参数2,要读取的系统状态的类型。性能数据类型(cpuinfo|batteryinfo|networkinfo|memoryinfo)
//参数3,尝试读取的次数(可选)
//返回 字符串数组类型,读取的系统状态信息,例如cpu,内存,网络流量和电池
5.电源设置
await driver.powerAC('on');
//将电池充电器的状态设置为已连接('on')或未连接('off')(仅模拟器)延迟1秒-2秒
await driver.powerCapacity(50);
//设置电池百分比(仅模拟器)
6.网络操作
await driver.toggleAirplaneMode();
//切换飞行模式(部分设备不可用)
await driver.toggleData();
//切换数据服务状态(部分设备不可用)
await driver.toggleWiFi();
//切换WiFi服务的状态
await driver.toggleLocationServices();
//切换位置服务的状态
await driver.sendSms('123456789', 'rpa');
//发送短信(仅模拟器)
await driver.gsmCall('123456789', 'call');
//拨打GSM 电话(仅模拟器)
await driver.gsmSignal(3);
//设置GSM 信号强大,信号强度在[0,4]范围内
await driver.gsmVoice('home');
//设置GSM 语音状态(仅模拟器)
//参数1 GSM 语音状态'unregistered'(未注册), 'home'(家庭), 'roaming'(漫游),
'searching'(搜索), 'denied'(被拒绝), 'off'(关闭),'on'(打开).
await driver.toggleNetworkSpeed('lte');
//设置网络速度(仅模拟器)
//参数1 网络类型'full','gsm','edge','hscsd','gprs','umts','hsdpa','lte','evdo'
7.键盘操作
await driver.pressKeyCode(10);
//按Android 设备上的特定键
//参数一,特定按键码值,4 为返回键。其他键值,自行百度搜索
await driver.longPressKeyCode(10);
//长按Android 设备上的特定键
await driver.hideKeyboard();
//隐藏软键盘
await driver.isKeyboardShown();
//判断是否显示软键盘,如果显示键盘,返回True
8.栏目相关
await driver.openNotifications();
//打开通知栏
await driver.getSystemBars();
//返回状态栏和导航栏的可见性信息
await driver.getDeviceTime();
//获取系统时间,返回系统时间(字符串)
await driver.getDisplayDensity();
//返回整型,设备pid(像素密度)
await driver.fingerPrint(1);
//指纹识别(仅模拟器)
//存储在Android Keystore 系统中的指纹(从1 到10)
9.触屏/鼠标操作
(1)鼠标操作(部分设备不可用)
moveTo(10, 10);
//将鼠标移动指定元素的偏移位置
click();
//在当前鼠标坐标处单击任意鼠标
doubleClick();
//双击元素
buttonDown();
//当前鼠标坐标处单击并按住鼠标左键
buttonUp();
//释放先前按住的鼠标按钮
(2).触屏操作
await driver.touchAction({
action: 'tap',
x: 30,
y: 20
});
//触摸xy指定坐标点
await driver.touchDoubleClick(element.elementId);
//在指定元素上触摸双击
//参数,元素id
await driver.touchPerform([
{ action: 'press', options: { x: 100, y: 250 }},
{ action: 'wait',options: {ms: 100}},
{ action: 'moveTo', options: { x: 300, y: 100 }},
{ action: 'release' }
]);
//触摸动作。action行为,options 行为参数
//行为:tap 点击 press 短按 longPress 长按 wait 等待 moveTo滑动 release 释放
//此函数涵盖鼠标和触屏操作,建议使用。 到10)
10.地理位置
await driver.getGeoLocation();
//获取地理位置,返回值整型 纬度 经度 高度
await driver.setGeoLocation({latitude: "121.21", longitude: "11.56", altitude: "94.23"});
//设置地理位置,latitude纬度 longitude经度 altitude高度
11.系统剪切板
await driver.getClipboard();
//获取系统剪贴板的内容 返回值,base64编码的字符串,如果剪贴板为空,则为空 字符串
var data = new Buffer.from("Ai-Bot").toString('base64');
await driver.setClipboard(data, 'plaintext');
//设置系统剪贴板的内容,仅设置plaintext纯文本
//参数1 字符串 base64编码
12.App操作
await driver.startActivity("com.example", "ActivityName");
//通过app包名称和活动名称来启动app 一般用于多个app控制
await driver.getCurrentActivity();
//返回当前app活动窗口的名称
await driver.getCurrentPackage();
//返回当前app包的名称
await driver.installApp("D: \\test.apk");
//安装app
await driver.removeApp("com.example.AppName");
//通过包名 卸载应用
await driver.isAppInstalled('com.example.AppName');
//检查设备上是否安装了指定的应用程序,如果已安装,返回true;否则,返回 false
await driver.launchApp();
//如果被测应用关闭或在后台运行 ,它将启动被测应用
await driver.background(10);
//将此会话当前运行的应用程序发送到后台,参数时间单位为秒
await driver.closeApp();
//关闭应用
await driver.reset();
//重置此会话的正在运行的应用
await driver.activateApp("com.example.AppName");
//通过包名 激活应用
await driver.terminateApp('com.example.AppName');
//终止设备上指定的应用
await driver.queryAppState('com.example.AppName');
//获取设备上应用状态。
//返回值,0未安装。1没有运行。2在后台运行或已暂停。 3在后台运行。4正在前台运行。
await driver.getStrings("en");
//获取应用程序所有的字符串。
await driver.getContext();
//获取当前app是在NATIVE还是WEBVIEW环境
//返回当前环境的名称
await driver.getContexts();
//获取app环境集合
//返回所有环境的名称(Array<String>
await driver.switchContext(contexts[1]);
//切换NATIVE或者WEBVIEW环境
//参数为 要更改环境的名称
await driver.getPageSource();
//获取当前的App层次结构XML(应用程序)或页面源码(Web)
//此方法获取App层次结构,便于元素定位
13.元素操作
(1)元素定位
await driver.$("~content-desc");
//元素定位支持content-desc、className、UiSelector、XPath等方式
//content-desc,UI元素的唯一标识符,该方式需在属性前加 "~" 波浪号
//className,类名定位,className属性值重复较多
//UiSelector,使用UI Automator API定位,可设定多个条件定位,建议使用
//XPath定位,效率较低,但它是通用的定位方式
//查找元素失败元素属性elementId值为undefined,可用作是否查找成功
示例代码:
//content-desc
await driver.$("~content-desc");
//className
await driver.$("className");
//UiSelector1
var selector ='new UiSelector().resourceId("resourceId")';
await driver.$(`android=${selector}`);
//UiSelector2
var selector ='new UiSelector().text("text").className("className").resourceId("resourceId")';
await driver.$(`android=${selector}`);
//XPath
await driver.$("//android.widget.TextView[@text='Ai-Bot']");
(2)元素数组
await driver.$$("className");
//查找相同元素属性值数组,查找方式同上
(3)元素方法
click();
//点击元素中心点
addValue("Ai-Bot");
//发送字符串到元素
setValue("Ai-Bot");
//设置元素值
clearValue();
//清除元素值
await driver.elementSubmit(formElement.elementId);
//提交表单元素
//参数一,元素id
(4)元素属性
getText();
//返回元素的可见文本
getTagName();
//获取标签名称
getAttribute("content-desc");
//获取元素指定属性的值,如果未设置返回 null
isSelected();
//判断元素是否被选择,返回值,boolean类型
isEnabled();
//判断当前元素是否可用,返回值,boolean类型
isDisplayed();
//判断当前元素是否可见,返回值,boolean类型
getLocation();
//获取元素在页面或屏幕上的顶点坐标,返回x、y,整型
getSize();
//获取元素宽和高,返回width、heigh
await driver.getElementRect(element.elementId);
//获取元素位置,返回x、y、width、height,矩形位置和大小
//参数1,元素id
getCSSProperty("style");
//获取元素指定的CSS属性值
await driver.getElementLocationInView(element.elementId);
//获取元素在页面或屏幕上的顶点坐标,返回x、y坐标,整型
await driver.getActiveElement();
//获取当前会话的活动元素
isEqual(element);
//判断指定元素与参数一是否引用同一个元素,返回值,boolean类型
//参数一,元素object
14.文件操作
var data = new Buffer.from("Hello World").toString('base64');
await driver.pushFile('/data/local/tmp/file.txt', data);
//上文件到设备
//参数一,文件路径
//参数二,base64格式的字符串
await driver.pullFile('/data/local/tmp/file.txt');
//获取设备上文件内容,返回值base64格式的字符串
await driver.pullFolder('/data/local/tmp/');
//获取设备指定文件夹,返回 Base64编码的字符串,文件格式为zip
15.执行adb
await driver.executeAsync('mobile: shell', {'command':'screencap -p /sdcard/app.png'});
//异步执行命令
await driver.execute('mobile: shell', {'command':'screencap -p /sdcard/app.png'});
//执行adb命令示例
16.批量执行
const script = `
let destElement = await driver.$('//android.widget.TextView[@text='移动网络']');
await destElement.click();`;
await driver.driverScript(script);
//执行多条命令
//此指令能提高脚本效率
17.web/窗口操作
await driver.switchToWindow("handle");
//将焦点切换另一个窗口
await driver.closeWindow();
//关闭当前窗口
await driver.getWindowHandle();
//获取当前窗口句柄
await driver.getWindowHandles();
//获取所有窗口句柄列表
await driver.getTitle();
//获取当前页面标题
await driver.getWindowRect();
//获取窗口的位置
await driver.setWindowRect(0, 0, 800, 600);
//设置窗口位置
await driver.getWindowSize();
//获取窗口大小
await driver.setWindowSize(10, 10);
//设置窗口大小
await driver.maximizeWindow();
//最大化窗口
await driver.url("http://www.ai-bot.net");
//打开新的URL
await driver.getUrl();
//获取当前页面url
await driver.back();
//返回
await driver.forward();
//前一页
await driver.refresh();
//刷新
await driver.getCookies();
//获取cookie
await driver.setCookies([{
name: 'myCookie',
value: 'some content'
}]);
//设置Cookie
await driver.deleteCookies("cookie_name");
//删除指定名称的cookie
await driver.deleteCookies();
//删除当前页面所有的cookie
await driver.switchToFrame(3);
//切换指定iframe
await driver.switchToParentFrame();
//切换父iframe

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
网站简介:精易论坛成立于2009年,是一个程序设计学习交流技术论坛,隶属于揭阳市揭东区精易科技有限公司所有。
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表