一.设备连接
1.usb单设备连接
d = u2.connect()
        2.usb多设备连接
d = u2.connect("90bf8faf")  # 多台设备填写device即可
        3.wifi连接
d = u2.connect("ip:proxy")  # wifi连接设备
        adb使用wifi连接设备:https://www.cnblogs.com/lihongtaoya/p/17553171.html
二.使用操作
1.点击
#  click点击
d(description="点按两次并按住可长按进入多选模式").click()  # 也可更加某点就行点击d.click(0.1,0.1)
# 单击直到元素消失,点击间隔1s,maxretry超时时长
d(description="点按两次并按住可长按进入多选模式").click_gone(maxretry=5, interval=1)
        2.长按
# 长按long_click
d(description="点按两次并按住可长按进入多选模式").long_click()
        3.文本
# 文本
d.send_keys("1234")  # 光标停留在输入框后直接sendkeys,自动切换fastinputime输入法
d.clear_text()  # 光标停留在输入框清空内容
        4.拖拽
1)元素到元素拖拽
# 元素到元素拖拽drag_to
d(text="SecoClient").drag_to(text="哔哩哔哩", duration=0.25)  # 将元素SecoClient拖到"哔哩哔哩"的位置,时间0.25s
        2)元素到坐标拖拽
# 元素到坐标的拖拽 drag_to
d(text="SecoClient").drag_to(0.603, 0.587, duration=0.25)
        3)坐标到坐标拖拽
# 两个坐标之间拖拽drag
d.drag(x1,y1,x2,y2)
        5.滑动
1)元素滚动
# 元素滑动"left", "right", "up", "down" 左右上下,一个步长5ms,20个step是100ms
d(text="SecoClient").swipe("up", steps=20)  # 将元素向上拖拽,时长100ms
        2)屏幕滚动
# 屏幕滑动  
x, y = d.window_size()  # 获取屏幕分辨率
x1 = x * 0.1
y1 = y * 0.3
y2 = y * 0.6
d.swipe(x1, y1, x1, y2)  # 手势向下滑,从竖屏30%的地方滑到60%的位置
d.swipe(x*0.9, y*0.1, x*0.1, y*0.1)  # 向右滑,从横屏90%的地方滑到10%的位置
        也可直接操作滑动
# 直接滑动  "left", "right", "up", "down" 左右上下
d.swipe_ext("left")
        3)界面滚动
滚动类型:horiz 为水平 vert 为垂直
滚动方向:forward 向前 , backward 向后 , toBeginning 滚动至开始 , toEnd 滚动至最后 ,to 滚动直接某个元素出现
# 界面滚动(界面是否可以滚动)  不太好用
d(scrollable=True).scroll.vert.toBeginning()  # 垂直滚动到页面顶部(不填vert,默认就是垂直)
d(scrollable=True).scroll.vert.toEnd()  # 垂直滚动到页面底部
d(scrollable=True).scroll.horiz.toEnd()  # 水平滚动置末尾,即最右侧
d(scrollable=True).scroll.horiz.toBeginning()  # 水平滚动置开头,即最左侧
d(scrollable=True).scroll.horiz.forward()  # 水平向前滚动一下
d(scrollable=True).scroll.horiz.backward()  # 水平向后滚动一下
d(scrollable=True).scroll.vert.forward()  # 垂直向下滚动一下
d(scrollable=True).scroll.vert.backward()  # 垂直向上滚动一下
        滚动置某一个元素停下来
# 滚动置某个元素停下
d(scrollable=True).scroll.vert.backward.to(resourceId="id/title", text="《系列》电影")  # 水平向上滚动到指定元素停下,向上找不到元素会往下滚动
d(scrollable=True).scroll.vert.toBeginning.to(text="SDK")  # 垂直向上到指定元素停下,向上到顶部找不到元素会往下滚动
        4)连续滚动
d.touch.down(x,y) 按住某个点
d.touch.sleep(5) 停留5s
d.touch.move(x,y) 移动到某点
d.touch.up(x,y) 在某点松开
# 连续滑动 touch(手机图案解锁)
d.touch.down(0.841, 0.477).sleep(3).up(0.841, 0.477)  # 在0.841, 0.477点击3s后松开,实现长按
# 从0.841, 0.477移动到0.827, 0.234后在0.186, 0.268松开,开始点击的时候长按0.2s,因为touch执行的特别快,按住图标后手机程序还没反应过来就结束了,导致滑动没有任何效果
d.touch.down(0.841, 0.477).sleep(0.2).move(0.827, 0.234).move(0.186, 0.268).up(0.186, 0.268)
        6.放大缩小
# 放大缩小
d(resourceId="com.vivo.gallery:id/gallery_root_bottom").pinch_in()  # 缩小
d(resourceId="com.vivo.gallery:id/gallery_root_bottom").pinch_out()  # 放大
# 指定放大缩小范围(单指1初位置)(单指2初位置)(滑动后单指1的位置)(滑动后单指2的位置)
d(resourceId="com.vivo.gallery:id/gallery_root_bottom").gesture((0.51, 0.327),(0.51,0.484),(0.51,0.147),(0.51,0.772))
        7.等待元素出现/消失
# 等待元素出现或消失
bol = d(text="哈哈").wait(timeout=3.0)  # 等待元素出现,时长3s,3s内出现返回true,未出现返回false
bol=d(text='哈哈').wait_gone(timeout=3)  # 等待元素消失,时长3s,3s内消失true,未消失返回false
        8.按键
# 按键
d.press("enter")  # 目前仅支持 home, back, left, right, up, down, center, menu, search, enter,delete(or del), recent(recent apps), volume_up, volume_down,volume_mute, camera, power
# 或
d.keyevent("enter")
        9.输入法切换
# 输入法切换
d.set_fastinput_ime(True)  # 设置默认输入法与fastinputime输入法转变(True为fastinputime,false默认输入法)
print(d.current_ime())  # 查看当前输入法
        10.模拟fastinputime输入法键盘操作
# 模拟fastinputime输入法键盘操作
d.send_action(5)  # 下一步
# 或
d.send_action("next")
# 目前仅支持如下几个
"""
"go": 2,
"search": 3,
"send": 4,
"next": 5,
"done": 6,
"previous": 7
"""
        11.截图
# 截图
d.screenshot("test.png")  # 当前项目目录下
        12.录制
1)安装依赖:pip install -U "uiautomator2[image]"
2)方法
d.screenrecord('test.mp4')  # 开始
time.sleep(2)
d.screenrecord.stop()  # 结束
        13.应用管理操作
1)获取当前页面信息
print(d.app_current())  # 获取当前页面信息:package,activity,pid
        2)安装app
d.app_install("url")  # 安装app
        3)启动app
d.app_start("package_name")
        4)获取app信息
print(d.app_info("package_name"))  # 获取app信息
        5)退出应用
退到后台
d.app_stop("package_name")  # 返回主界面
        清除缓存(杀进程)
d.app_clear("package_name")  # 杀进程清除缓存
        6)获取设备ip
print(d.wlan_ip)  # 手机ip
        7)获取设备信息(cpu,电池等)
print(d.device_info)  # 获取设备信息(型号,cpu,电池等信息)
        8)卸载app
d.app_uninstall('tv.danmaku.bili')  # 卸载
        9)等待应用启动
"""
等待应用变为当前应用,返回pid,超时未启动成功则返回0
front为true表示等待app成为当前app,
默认为false,表示只要后台有这个应用的进程就会返回PID
"""
a=d.app_wait("com.tencent.wework",6,front=True)  # 返回pid
print(a)
        13.全局设置
1)查看默认配置
print(d.settings) 
"""
{
'fallback_to_blank_screenshot': False,
 'operation_delay': (0, 5),   点击元素后延迟0-5秒
 'operation_delay_methods': ['click', 'swipe'],  点击元素延迟时间生效的方法(可以增加press,send_keys等 )
 'wait_timeout': 20.0,  查找元素默认等待时长
 'xpath_debug': False  xpath日志
 }
"""
        2)修改默认配置
d.settings["wait_timeout"]=10  # 修改设置,按照字典来修改即可
        全局等待时长还可通过implicitly_wait来设置
d.implicitly_wait(10)
        14.息/亮屏
d.screen_off()  # 息屏(锁屏)
d.sleep(5)
d.screen_on()  # 亮屏
        15.通知栏操作
d.open_notification()  # 打开通知栏
d.open_quick_settings()  # 打开通知栏设置页
        16.停止ATX服务
d.service("uiautomator").stop()  # 停止atx服务
        17.读取devices信息
print(d.info)
        三.实例
以市场上一个可以开播的软件为了实现登录开播


import uiautomator2 as u2
class Uiautomator2App:
    def __init__(self):
        self.d = u2.connect()
        self.d.implicitly_wait(10)
        self.d.app_start("tv.dm")
    def login(self):
        self.d(text="其他登录方式").click()
        self.d(resourceId="android:id/button1").click()  # 密码登录
        self.d(resourceId="tv.dm:id/username").click()
        self.d.send_keys("用户名")
        self.d.send_action(5)
        self.d.send_keys("密码")
        self.d(resourceId="tv.dm:id/log_reg_checkbox").click()  # 勾选协议
        self.d(resourceId="tv.dm:id/btn_login").click()  # 登录
    def bo(self):
        while True:
            if self.d(resourceId="tv.dm:id/tab_text", text="首页").wait(timeout=3.0):
                self.d.click(0.487, 0.968)  # 进入直播页面
                break
            else:
                continue
        self.d.xpath(
            '//*[@resource-id="tv.dm:id/wtlTabs"]/android.widget.LinearLayout[1]/android.widget.RelativeLayout['
            '1]/android.widget.FrameLayout[1]').click()  # 开启直播
    def exit(self):
        self.d.app_clear("tv.dm:id")  # 退出应用
if __name__ == '__main__':
    u = Uiautomator2App()
    u.login()
    u.bo()
    u.exit()
        import uiautomator2 as u2