百度多次未找到遍历一个uiautomator2中子元素的方法,通过自己查看实现代码,找到了方法,分享出来供大家参考。

 

当你获取了页面某个元素之后 elements = d('//*[@clickable="true"]').all()

返回的是一个list,其中是<uiautomator2.xpath.XMLElement>类型的变量。

可以通过以下方式获取它所有子类的信息。

for ele in elements:
    children = ele.elem.getchildren()

注意,其中的ele.elem是<lxml.etree._Element>类型的变量。

这种变量才能获取到对应控件元素的属性,比如text、resourceID等等。方法是 ele.elem.get("text"),其中的key可以通过 ele.elem.keys()查看,如下

['index', 'text', 'resource-id', 'package', 'content-desc', 'checkable', 'checked', 'clickable', 'enabled', 'focusable', 'focused', 'scrollable', 'long-clickable', 'password', 'selected', 'visible-to-user', 'bounds']

【总结】

综上,你若想遍历某个元素的所有子元素

for ele in elements:
    children = ele.elem.getchildren()
        for child in children:
            print(child.get("text")
            grandchildren = child.getchildren() # 注意和 ele.elem.children的区别
            ....#后续可以自行写递归函数循环