使用Selenium + Chromedriver出现的问题

在win7+Eclipse Neon+selenium 2.53环境下,遇到Selenium启动异常SessionNotCreatedException,以及NoSuchElementException、StaleElementReferenceException。问题可能源于页面加载状态、元素定位及代码执行速度。解决方案包括增加休眠时间、检查分辨率和使用try-catch进行异常处理。建议在遇到此类问题时,利用webdirver截图分析状况。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

环境:win7+Eclipse Neon+selenium  2.53

问题一:

selenium无法启动org.openqa.selenium.SessionNotCreatedException:session not created exception

解决方法:
本机的chrome 为61版本,更新chrome driver的版本即可

补充
如果webdriver是用remotedriver实例化(什么意思),则会提示如下错误,排除地址错误或者服务器没有启动的因素,原因跟上面是一样的,更换版本就好了。
Could not start a new session. Possible causes are invalid address of the remote server or browser start-up failure


问题二:

http://blog.youkuaiyun.com/wlh5520/article/details/31353463


问题三:

现象:出现报错org.openqa.selenium.NoSuchElementException: Unable to locate element

原因:进入网页时,网页可能在loading中,因此找不到元素。

解决方法:你可以让他休眠Thread.sleep(2000),即休眠2秒,应该可以找到元素了。

问题三消失了,引出了问题四


问题四:

Exception in thread "main" org.openqa.selenium.StaleElementReferenceExceptionstale element reference: element is not attached to the page document

这个报错意思是找得到元素,但是它不在当前可见的页面上。可能性很多:

  1. 上个操作和下个操作间隔时间太短,代码执行速度比页面渲染速度快。

  2. 分辨率问题,运行环境驱动与调试的驱动不一样。

    建议:用try的方法,失败的时候通过webdirver截一下图看是什么情况。


还未解决


### 一、SeleniumChromedriver简介 Selenium 是一种用于自动化浏览器操作的工具,广泛应用于 Web 应用程序的功能测试和性能测试。ChromeDriver 是一个独立的可执行文件,用于控制 Google Chrome 浏览器实例,使 Selenium 能够与 Chrome 浏览器交互[^1]。 ### 二、安装与配置步骤 #### 1. 安装 Selenium 确保系统中已安装 Python 环境后,可以通过以下命令安装 Selenium: ```bash pip install selenium ``` #### 2. 查看 Chrome 浏览器版本 在安装 ChromeDriver 之前,需要确认本地安装的 Chrome 浏览器版本。打开 Chrome 浏览器,进入设置页面,点击“关于 Chrome”,即可查看当前版本号[^3]。 #### 3. 下载并配置 ChromeDriver 根据 Chrome 浏览器的版本号,从官方下载地址下载对应的 ChromeDriver 版本[^4]: ```bash wget http://chromedriver.storage.googleapis.com/<version>/chromedriver_linux64.zip unzip chromedriver_linux64.zip ``` 将解压后的 `chromedriver` 文件移动到系统的 PATH 环境变量路径下,例如 `/usr/local/bin`,以确保全局可用[^1]。 #### 4. 配置环境变量 如果未将 ChromeDriver 添加到系统 PATH 中,则需要在代码中指定其路径。例如: ```python from selenium import webdriver driver = webdriver.Chrome(executable_path='/path/to/chromedriver') driver.get("https://www.baidu.com") ``` ### 三、使用示例 以下是一个简单的 Selenium 自动化测试代码示例,演示如何打开百度首页并搜索关键词[^2]: ```python from selenium import webdriver from selenium.webdriver.common.by import By from selenium.webdriver.common.keys import Keys # 初始化 Chrome 浏览器驱动 driver = webdriver.Chrome() try: # 打开百度首页 driver.get("https://www.baidu.com") # 定位搜索框并输入关键词 search_box = driver.find_element(By.ID, "kw") search_box.send_keys("Selenium Chromedriver") search_box.send_keys(Keys.RETURN) # 等待页面加载完成 driver.implicitly_wait(10) finally: # 关闭浏览器 driver.quit() ``` ### 四、高级配置 为了增强 Selenium 的功能或兼容性,可以使用 `DesiredCapabilities` 和 `ChromeOptions` 进行更精细的配置[^3]。例如,在无头模式(Headless Mode)下运行 Chrome 浏览器: ```python from selenium import webdriver from selenium.webdriver.chrome.service import Service from selenium.webdriver.chrome.options import Options # 设置 Chrome 选项 chrome_options = Options() chrome_options.add_argument("--headless") # 无头模式 chrome_options.add_argument("--disable-gpu") # 禁用 GPU 加速 # 指定 ChromeDriver 路径 service = Service('/path/to/chromedriver') # 初始化 WebDriver driver = webdriver.Chrome(service=service, options=chrome_options) # 访问网页 driver.get("https://www.baidu.com") print(driver.title) # 关闭浏览器 driver.quit() ``` ### 五、常见问题及解决方法 1. **ChromeDriver 版本不匹配**:确保 ChromeDriver 的版本与本地 Chrome 浏览器版本一致[^4]。 2. **无法找到 ChromeDriver**:检查是否正确设置了 PATH 环境变量或是否在代码中指定了正确的路径。 3. **无头模式报错**:在某些系统上可能需要额外参数,例如 `--no-sandbox` 或 `--disable-dev-shm-usage`。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值