【appium】6.appium遇到的问题

1.appium-python-client 修改版本1.5 为5.1.1,后执行python程序时,提示: raise TypeError( TypeError: missing 1 required keyword-only argument: 'options' (instance of driver `options.Options` class)

你遇到的错误:

复制代码
TypeError: missing 1 required keyword-only argument: 'options' 
(instance of driver `options.Options` class)

📌 错误原因分析

这是 Appium-Python-Client 版本升级带来的 API 不兼容问题

你从版本 1.5 升级到了 5.1.1,这是一个非常大的版本跳跃,其中 Appium 客户端库进行了重大更新(主要是与 Selenium 的整合和重构)。


🔍 旧版 vs 新版 WebDriver 初始化方式对比

✅ 旧版(Appium-Python-Client < 3.x)

复制代码
from appium import webdriver

desired_caps = {
    'platformName': 'Android',
    'deviceName': 'emulator-5554',
    'appPackage': 'com.example.app',
    'appActivity': '.MainActivity'
}

driver = webdriver.Remote('http://localhost:4723', desired_caps)

这个写法在新版本中已经不被支持了!


✅ 新版(Appium-Python-Client ≥ 5.0)

现在要求使用 options 参数来代替直接传入 desired_caps,这与新版 Selenium 的风格一致。


✅ 正确修改方法(适用于 Appium-Python-Client 5.1.1)

你需要将原来的 desired_caps 放入一个 options 对象中。

✅ 修改后的代码如下:

复制代码
from appium import webdriver
from appium.options.android import UiAutomator2Options

# 设置 Desired Capabilities
desired_caps = {
    'platformName': 'Android',
    'deviceName': 'emulator-5554',
    'appPackage': 'com.example.app',
    'appActivity': '.MainActivity',
    'automationName': 'UiAutomator2',
    'noReset': True
}

# 使用新的 Options 类封装
options = UiAutomator2Options().load_capabilities(desired_caps)

# 创建 WebDriver 实例
driver = webdriver.Remote(
    command_executor='http://localhost:4723',
    options=options
)

print("Driver started:", driver)

🧪 常见注意事项

注意事项 说明
UiAutomator2Options Android 测试时推荐使用这个类
options 是必须参数 新版要求必须使用 options 而不是 desired_caps
command_executor 就是你的 Appium Server 地址:http://localhost:4723

✅ 如何降级回旧版本?(可选)

如果你暂时不想改代码,可以考虑降级到旧版本:

复制代码
pip install Appium-Python-Client==1.5.0

但这只是临时方案,建议尽快迁移到新版 API。


✅ 总结

问题 解决方法
TypeError: missing keyword-only argument 'options' 使用 options 参数代替 desired_caps
Appium Python Client 5.1.1 兼容性问题 使用 UiAutomator2Options.load_capabilities() 包装 desired_caps
推荐做法 使用新版 API,适配未来更新

如果你愿意贴出你的完整代码片段,我可以帮你逐行修改成兼容 5.1.1 的写法。欢迎继续提问!

相关推荐
Wpa.wk4 小时前
APP自动化-Appium环境安装
运维·appium·自动化
Wpa.wk1 天前
APP自动化-Appium原理
运维·appium·自动化
测试员周周3 天前
【Appium 系列】第12节-智能路由 — API测试 vs UI 测试的自动选择
开发语言·人工智能·python·功能测试·ui·appium·测试用例
测试员周周4 天前
【Appium 系列】第09节-数据驱动测试 — YAML 数据 + parametrize
服务器·数据库·人工智能·python·测试工具·语言模型·appium
测试员周周4 天前
【Appium 系列】第10节-手势操作实战 — 滑动、拖拽、缩放与轻拂
linux·服务器·开发语言·人工智能·python·appium·pytest
测试员周周5 天前
【Appium 系列】第06节-页面对象实现 — LoginPage 实战
开发语言·前端·人工智能·python·功能测试·appium·测试用例
测试员周周5 天前
【Appium 系列】第07节-API测试封装 — BaseAPI 的设计与实现
开发语言·人工智能·功能测试·测试工具·appium·自动化·测试用例
测试员周周5 天前
【Appium 系列】第08节-pytest 集成 — conftest.py 中的 fixture 与 hook
开发语言·人工智能·python·功能测试·appium·测试用例·pytest
测试员周周6 天前
【Appium 系列】第04节-Page Object 模式 — BasePage 基类设计
开发语言·数据库·人工智能·python·语言模型·appium·web app
测试员周周6 天前
【Appium 系列】第02节-环境搭建 — Android + iOS 双平台环境配置
开发语言·人工智能·功能测试·appium·自动化·测试用例·web app