Airtest:各平台的剪切板功能汇总

简介: Airtest:各平台的剪切板功能汇总


版权声明:允许转载,但转载必须保留原链接;请勿用作商业或者非法用途

1. 前言

一直以来,大家都还挺关注 Airtest是否有剪切板功能 的。从Airtest1.3.1版本起,我们新增了Android、iOS设备的剪切板功能,自此,3大平台的剪切板功能就齐全啦。

正好趁这个机会,我们给各大平台的剪切板功能做个合集,方便同学们查阅使用~

2. Android设备的剪切板功能

Android设备的剪切板功能包含设置剪切板内容、获取剪切板内容、剪切板粘贴:

image.png

# -*- encoding=utf8 -*-
__author__ = "AirtestProject"
from airtest.core.api import *
auto_setup(__file__)
text_1 = "test_clipboard"
set_clipboard(text_1) # 设置剪切板内容
get_text = get_clipboard() # 获得剪切板内容
print(get_text)  # -> test_clipboard
# 剪切板粘贴接口
paste()  # => text(get_clipboard())

3. iOS设备的剪切板功能

iOS的剪切板功能和Android是大同小异的;对于本地iOS设备,特别是本地机器上只安装了一个WDA的,我们无需在使用剪切板功能时指定WDA的bundle ID:

image.png

但是 对于远程iOS设备,我们必须指定定WDA的bundle ID

# 远程iOS设备
text_1 = "test_clipboard"
bundle_id = "com.2303xxxxxxxxx.WebDriverAgentRunner.xctrunner"
set_clipboard(text_1,bundle_id) # 设置剪切板内容
get_text = get_clipboard(bundle_id) # 获得剪切板内容
print(get_text)  # -> test_clipboard
# 剪切板粘贴接口
paste(bundle_id)  # => text(get_clipboard())

否则会出现如下的报错:

Traceback (most recent call last):
  File "airtest\cli\runner.py", line 75, in runTest
  File "site-packages\six.py", line 703, in reraise
  File "airtest\cli\runner.py", line 72, in runTest
  File "D:\demo\untitled.air\untitled.py", line 9, in <module>
    set_clipboard(text_1) # 设置剪切板内容
  File "airtest\utils\logwraper.py", line 131, in wrapper
  File "airtest\core\api.py", line 698, in set_clipboard
  File "E:\AirtestIDE-win-1.2.16\AirtestIDE\airtest\core\ios\ios.py", line 47, in wrapper
    return func(self, *args, **kwargs)
  File "E:\AirtestIDE-win-1.2.16\AirtestIDE\airtest\core\ios\ios.py", line 956, in set_clipboard
    e.g. set_clipboard('content', 'wda_bundle_id').")
RuntimeError: Remote device need to set running wda bundle id parameter,                                     e.g. set_clipboard('content', 'wda_bundle_id').
----------------------------------------------------------------------
Ran 1 test in 2.169s
FAILED (errors=1)
[Finished]

1)小tips:关于如何获取WDA的bundle ID

我们可以使用Airtest1.3.0新增的iOS接口来查询:

# -*- encoding=utf8 -*-
__author__ = "AirtestProject"
from airtest.core.api import *
import airtest
auto_setup(__file__)
dev = device()
#列出并打印用户安装的APP
print("---------以下是用户安装的APP的信息-----------")
user_app = dev.list_app("user")
print(user_app)

此时,我们安装在手机上的WDA信息也会被打印出来,不过 该方式只能适用于本地的iOS设备

4. Windows平台的剪切板功能

对于Windows应用,Airtest虽然没有封装专门的剪切板功能,但其实我们都知道,Windows平台的复制粘贴就是键盘操作 “Ctrl+C”、“Ctrl+V”,并且Airtest封装有 keyevent 接口,支持我们执行键盘操作:

image.png

# -*- encoding=utf8 -*-
__author__ = "AirtestProject"
from airtest.core.api import *
auto_setup(__file__)
text("11111111")
# 模拟按键Ctrl+A,实现全选文本
keyevent("^a")
# 模拟按键Ctrl+C,实现复制文本
keyevent("^c")
# 回车换行
keyevent("{ENTER}")
# 模拟按键Ctrl+V,实现复制文本
keyevent("^v")

(其实,pywin32 的模块里面也有一些现成的关于Windows剪切板功能的接口,感兴趣的同学可以自行网上查阅资料~)

5. 小结

至此,3大平台的剪切板功能就介绍到这里啦,后续同学们还想看怎样的教程,欢迎给我们留言/投稿!

相关文章
|
NoSQL 关系型数据库 MySQL
Redis之秒杀系统
秒杀是一种高并发场景,通常指的是在短时间内(秒级别)有大量用户同时访问某个商品或服务,争相抢购的情景。在这种情况下,系统需要处理大量并发请求,确保公平性、一致性,并防止因并发而导致的问题,例如超卖、恶意请求等。以下是在高并发秒杀场景下需要考虑的一些关键问题和解决方案:
276 0
|
安全 开发工具 git
【Git】—— 分支管理策略
【Git】—— 分支管理策略
214 0
|
Rust JavaScript Go
2024年十大值得关注的编程语言
探索2024年最有影响力的编程语言:Python的多功能无与伦比,JavaScript在Web领域的统治地位,Rust的高效性,等等。
|
12月前
|
人工智能 JavaScript 定位技术
微信的接口都有哪些?
【10月更文挑战第17天】微信的接口都有哪些?
982 43
|
4月前
|
测试技术
字节Seed开源统一多模态理解和生成模型 BAGEL!
近期,字节跳动Seed推出了 BAGEL—— 一个开源的多模态理解和生成础模型,具有70亿个激活参数(总共140亿个),并在大规模交错多模态数据上进行训练。
282 3
|
NoSQL Ubuntu Linux
基于ARM64的Qemu/KVM学习环境搭建2
基于ARM64的Qemu/KVM学习环境搭建2
|
11月前
|
运维 监控 持续交付
云计算环境下的运维自动化实践
本文探讨了在云计算环境下实施运维自动化的必要性、挑战及解决方案,重点介绍了如何利用现代技术工具实现高效的云资源管理和监控。通过具体案例分析,展示了自动化运维在提升系统稳定性、降低人力成本方面的优势。
|
11月前
|
SQL 关系型数据库 MySQL
MySQL性能探究:count(*)与count(1)的性能对决
在MySQL数据库的性能优化中,对查询语句的细微差别有着深入的理解是非常重要的。`count(*)`和`count(1)`是两种常用的聚合函数,用于计算行数。在面试中,面试官经常会问到这两种函数的性能差异。本文将探讨`count(*)`与`count(1)`的性能对比,并整理十道经典的MySQL面试题,帮助你在面试中游刃有余。
294 3
|
数据采集 关系型数据库 MySQL
MySQL表约束的种类与应用
在设计数据库时,合理应用各种约束对于创建一个结构化良好且能够有效维护数据完整性的数据库至关重要。每种约束类型都有其特定的应用场景,理解并正确应用这些约束,可以大大提高数据库应用的稳定性和性能。
241 3
|
JavaScript 前端开发 Java
一个基于 SpringBoot + Vue 的在线考试系统
【9月更文挑战第24天】这是一个基于 Spring Boot 和 Vue 构建的在线考试系统。后端采用 Spring Boot、Spring Data JPA 和 MySQL 实现快速开发和数据库操作;前端使用 Vue.js 和 Element UI 快速搭建界面。系统包括用户管理、考试管理、考试答题和成绩管理等功能模块,并设计了相应的数据库表结构。通过 RESTful API 实现前后端数据交互,支持多种题型和权限管理,适用于学校和企业等场景。
367 2