手机自动化测试:5.模拟相关操作:swipe,scroll,drag_and_dropki

网上教程很多。以下仅参考。

1.swipe(坐标到坐标)

复制代码
time.sleep(3)
print("滑动开始")

driver.swipe(500,1500,500,500)
print("滑动结束")

2. scroll(元素到元素)

先定位元素组:

复制代码
//android.support.v7.widget.RecyclerView/android.widget.FrameLayout/android.view.ViewGroup/android.view.ViewGroup

以下代码,获取元素列表成功。我们要利用这些个元素进行滚动的。

以下代码,滚动成功。注意的是:我使用的是-2和1,因为我用-1和0时老是滚动失败,原因以后再找吧。

复制代码
# ########################## 定位数据区域,返回元素列表每次定位的有点多,所以使用字典去重 #########################################################
try:
    # 使用XPath定位带有index属性的FrameLayout元素
    frame_layout_elements = WebDriverWait(driver, timeout, poll_frequency).until(
        EC.presence_of_all_elements_located(
            (By.XPATH, "//android.support.v7.widget.RecyclerView/android.widget.FrameLayout/android.view.ViewGroup/android.view.ViewGroup"))
    )
    print("元素列表长度:", len(frame_layout_elements))

    for i in range(len(frame_layout_elements)):

        print("元素列表:",frame_layout_elements[i])

    print("准备元素滑动")
    time.sleep(5)
    driver.scroll(frame_layout_elements[-2], frame_layout_elements[1])


    # 根据需要进一步操作找到的唯一FrameLayout元素
except Exception as e:
    print(f"无法定位到FrameLayout元素: {e}")

3.drag_and_drop(元素,无素)

直接修改以上代码。以下测试通过。

复制代码
# ########################## 定位数据区域,返回元素列表每次定位的有点多,所以使用字典去重 #########################################################
try:
    # 使用XPath定位带有index属性的FrameLayout元素
    frame_layout_elements = WebDriverWait(driver, timeout, poll_frequency).until(
        EC.presence_of_all_elements_located(
            (By.XPATH, "//android.support.v7.widget.RecyclerView/android.widget.FrameLayout/android.view.ViewGroup/android.view.ViewGroup"))
    )
    print("元素列表长度:", len(frame_layout_elements))

    for i in range(len(frame_layout_elements)):

        print("元素列表:",frame_layout_elements[i])

    print("准备元素滑动")
    time.sleep(5)
    driver.drag_and_drop(frame_layout_elements[-2], frame_layout_elements[1])


    # 根据需要进一步操作找到的唯一FrameLayout元素
except Exception as e:
    print(f"无法定位到FrameLayout元素: {e}")

下一节,对每一个元素块内的文字进行提取

相关推荐
我是哈哈hh7 分钟前
【Node.js】ECMAScript标准 以及 npm安装
开发语言·前端·javascript·node.js
张元清29 分钟前
电商 Feeds 流缓存策略:Temu vs 拼多多的技术选择
前端·javascript·面试
一枚前端小能手30 分钟前
🎨 CSS布局从入门到放弃?Grid让你重新爱上布局
前端·css
晴空雨31 分钟前
React 合成事件原理:从事件委托到 React 17 的重大改进
前端·react.js
魏嗣宗33 分钟前
Node.js 网络编程全解析:从 Socket 到 HTTP,再到流式协议
前端·全栈
pepedd86434 分钟前
还在开发vue2老项目吗?本文带你梳理vue版本区别
前端·vue.js·trae
pepedd8641 小时前
浅谈js拷贝问题-解决拷贝数据难题
前端·javascript·trae
@大迁世界1 小时前
useCallback 的陷阱:当 React Hooks 反而拖了后腿
前端·javascript·react.js·前端框架·ecmascript
跟橙姐学代码1 小时前
学Python别死记硬背,这份“编程生活化笔记”让你少走三年弯路
前端·python
前端缘梦1 小时前
深入理解 Vue 中的虚拟 DOM:原理与实战价值
前端·vue.js·面试