当前位置: 代码网 > it编程>前端脚本>Python > Python使用Selenium模拟浏览器操作的完整指南

Python使用Selenium模拟浏览器操作的完整指南

2026年01月04日 Python 我要评论
引言selenium 核心价值在于模拟真实用户的浏览器操作行为,能够精准还原打开页面、输入文本、点击按钮、滚动页面等一系列操作,完美解决动态 网页的数据爬取和自动化场景需求。本文将从实操角度出发,详细

引言

selenium 核心价值在于模拟真实用户的浏览器操作行为,能够精准还原打开页面、输入文本、点击按钮、滚动页面等一系列操作,完美解决动态 网页的数据爬取和自动化场景需求。本文将从实操角度出发,详细讲解 selenium 模拟各类浏览器操作的核心方法,附带完整可运行代码。

一、前期准备(回顾必备)

  1. 已安装 selenium 库:pip install selenium -i https://pypi.doubanio.com/simple/
  2. 已配置对应浏览器驱动(chromedriver 优先,版本与浏览器大版本一致)
  3. 核心导入模块(后续示例默认包含以下导入):
from selenium import webdriver
from selenium.webdriver.common.by import by
from selenium.webdriver.common.keys import keys
import time

二、基础操作:初始化浏览器与访问网页

这是模拟浏览器操作的第一步,完成浏览器的启动、配置与目标网页的访问。

1. 基础初始化(可视化模式)

# 1. 初始化 chrome 浏览器驱动(启动浏览器)
driver = webdriver.chrome()

# 2. 可选:最大化浏览器窗口(模拟用户正常使用习惯)
driver.maximize_window()

# 3. 访问目标网页(get 方法会等待页面初步加载完成)
target_url = "https://www.baidu.com"
driver.get(target_url)
print(f"已成功访问:{target_url},当前页面标题:{driver.title}")

# 4. 可选:短暂延时,确保页面完全渲染(后续优先使用显式等待)
time.sleep(2)

2. 无界面模式(后台运行,不显示浏览器窗口)

适合服务器运行或无需可视化的场景,节省系统资源:

# 1. 构造 chrome 配置对象
chrome_options = webdriver.chromeoptions()
# 启用无界面模式(selenium 4.x 推荐写法)
chrome_options.add_argument("--headless=new")
# 禁用 gpu 加速,避免部分环境报错
chrome_options.add_argument("--disable-gpu")

# 2. 传入配置初始化浏览器
driver = webdriver.chrome(options=chrome_options)
driver.get("https://www.baidu.com")
print(f"无界面模式:页面标题为 {driver.title}")

三、核心操作1:定位页面元素(操作的前提)

模拟浏览器操作的核心是「先定位元素,再执行操作」,selenium 提供了 6 种常用定位方式,其中 id、xpath、css 选择器 最为实用,优先掌握。

定位方式语法(by.xxx)适用场景
id 定位by.id元素 id 唯一(高效精准,优先使用)
xpath 定位by.xpath万能灵活,可应对复杂页面(无唯一 id/class 时首选)
css 选择器by.css_selector高效,与前端开发语法一致
name 定位by.name元素有唯一 name 属性
标签名定位by.tag_name批量查找相同标签(如所有 <a> 标签)
链接文本定位by.link_text精准匹配 <a> 标签的完整文本

实操示例(以百度首页为例)

driver = webdriver.chrome()
driver.maximize_window()
driver.get("https://www.baidu.com")
time.sleep(2)

# 1. id 定位(百度搜索框 id 为 "kw")
search_input = driver.find_element(by.id, "kw")
print("id 定位成功:", search_input.tag_name)

# 2. xpath 定位(相对路径,容错性强)
search_button = driver.find_element(by.xpath, '//input[@id="su"]')
print("xpath 定位成功:", search_button.tag_name)

# 3. css 选择器定位(# 表示 id,. 表示 class)
news_link = driver.find_element(by.css_selector, 'a[href="https://news.baidu.com" rel="external nofollow" ]')
print("css 选择器定位成功:", news_link.text)

driver.quit()

说明:driver.find_element() 返回第一个匹配元素,driver.find_elements() 返回所有匹配元素列表(无匹配返回空列表)。

四、核心操作2:模拟用户常用交互行为

1. 输入与清空文本(如搜索框、登录输入框)

使用 send_keys() 输入文本,clear() 清空输入框内容,是表单操作的核心方法。

driver = webdriver.chrome()
driver.maximize_window()
driver.get("https://www.baidu.com")
time.sleep(2)

# 1. 定位搜索框,输入关键词
search_input = driver.find_element(by.id, "kw")
search_input.send_keys("selenium 模拟浏览器操作")  # 输入任意文本(支持中文)
print("已输入搜索关键词")
time.sleep(2)

# 2. 清空搜索框内容(可选)
search_input.clear()
print("已清空搜索框")
time.sleep(1)

# 3. 重新输入并回车提交搜索(结合 keys 类模拟键盘操作)
search_input.send_keys("python 爬虫进阶")
search_input.send_keys(keys.enter)  # 模拟按下回车键
print("已提交搜索,等待结果加载")
time.sleep(3)

driver.quit()

2. 模拟点击操作(按钮、链接、复选框等)

使用 click() 方法模拟用户左键点击,支持所有可点击元素(按钮、<a> 标签、单选框等)。

driver = webdriver.chrome()
driver.maximize_window()
driver.get("https://www.baidu.com")
time.sleep(2)

# 1. 定位搜索框,输入关键词
search_input = driver.find_element(by.id, "kw")
search_input.send_keys("selenium 教程")

# 2. 定位搜索按钮,模拟点击提交
search_button = driver.find_element(by.id, "su")
search_button.click()  # 核心点击方法
print("点击搜索按钮,提交查询")
time.sleep(3)

# 3. 定位搜索结果中的链接,点击跳转
first_result = driver.find_element(by.xpath, '//div[@id="content_left"]//a[1]')
first_result.click()
print("点击第一条搜索结果,跳转新页面")
time.sleep(3)

driver.quit()

3. 模拟页面滚动(应对滚动加载、查看更多内容)

动态 网页常需要滚动页面才能加载更多数据,selenium 推荐使用 execute_script() 执行 javascript 脚本实现滚动,万能且稳定。

driver = webdriver.chrome()
driver.maximize_window()
driver.get("https://www.runoob.com/python/python-blog.html")
time.sleep(2)

# 1. 滚动到页面底部(获取完整动态数据)
driver.execute_script("window.scrollto(0, document.body.scrollheight);")
print("已滚动到页面底部")
time.sleep(3)

# 2. 滚动到页面顶部
driver.execute_script("window.scrollto(0, 0);")
print("已滚动到页面顶部")
time.sleep(2)

# 3. 滚动到指定位置(横向 x=0,纵向 y=800 像素)
driver.execute_script("window.scrollto(0, 800);")
print("已滚动到页面 y=800 位置")
time.sleep(2)

# 4. 模拟逐页滚动(pagedown 键)
driver.find_element(by.tag_name, "body").send_keys(keys.page_down)
print("已向下滚动一页")
time.sleep(2)

driver.quit()

4. 浏览器窗口辅助操作(刷新、前进、后退、关闭)

模拟用户对浏览器窗口的常用操作,完善自动化流程:

driver = webdriver.chrome()
driver.maximize_window()
driver.get("https://www.baidu.com")
time.sleep(2)

# 1. 刷新当前页面
driver.refresh()
print("已刷新页面")
time.sleep(2)

# 2. 访问新页面(为后续前进/后退做准备)
driver.get("https://www.runoob.com")
print("已访问菜鸟教程")
time.sleep(2)

# 3. 后退到上一个页面(百度首页)
driver.back()
print("已后退到百度首页")
time.sleep(2)

# 4. 前进到下一个页面(菜鸟教程)
driver.forward()
print("已前进到菜鸟教程")
time.sleep(2)

# 5. 关闭浏览器(释放所有资源,推荐使用 quit() 而非 close())
# driver.close()  # 关闭当前窗口(多窗口时适用)
driver.quit()  # 退出浏览器,释放所有资源
print("浏览器已关闭")

五、关键优化:等待元素加载(避免操作失败)

动态 网页存在加载延迟,直接执行操作可能会因元素未加载完成而抛出 nosuchelementexception 异常。selenium 提供 3 种等待策略,显式等待 是最优选择。

1. 强制等待(最简单,不推荐)

time.sleep(seconds),固定延时,无论页面是否加载完成都等待,适合简单场景或临时调试。

driver.get("https://www.baidu.com")
time.sleep(2)  # 固定等待 2 秒

2. 隐式等待(全局生效,中等推荐)

通过 driver.implicitly_wait(seconds) 设置全局等待时间,在指定时间内会不断尝试定位元素,直到找到或超时。

driver = webdriver.chrome()
# 设置隐式等待 10 秒(全局生效,仅对元素定位操作有效)
driver.implicitly_wait(10)
driver.get("https://www.baidu.com")

# 若 10 秒内找到元素则立即执行,否则抛出异常
search_input = driver.find_element(by.id, "kw")
search_input.send_keys("隐式等待测试")
driver.quit()

3. 显式等待(灵活高效,强烈推荐)

通过 webdriverwait 配合 expected_conditions,针对单个元素设置个性化等待条件(如元素可见、可点击),超时后抛出明确异常,适合复杂动态页面。

from selenium.webdriver.support.ui import webdriverwait
from selenium.webdriver.support import expected_conditions as ec

driver = webdriver.chrome()
driver.maximize_window()
driver.get("https://www.baidu.com")

# 1. 构造显式等待对象(最长等待 10 秒,每 0.5 秒检查一次条件)
wait = webdriverwait(driver, 10, poll_frequency=0.5)

# 2. 等待搜索框可点击(常用条件:element_to_be_clickable)
search_input = wait.until(
    ec.element_to_be_clickable((by.id, "kw")),
    message="超时:未找到可点击的百度搜索框"
)

# 3. 元素加载完成后执行操作
search_input.send_keys("显式等待测试")
print("输入成功,等待条件满足")

driver.quit()

常用等待条件:ec.visibility_of_element_located()(元素可见)、ec.presence_of_element_located()(元素存在于 dom 中)、ec.element_to_be_clickable()(元素可点击)。

六、完整实战:模拟浏览器完成搜索+滚动+数据提取

from selenium import webdriver
from selenium.webdriver.common.by import by
from selenium.webdriver.common.keys import keys
from selenium.webdriver.support.ui import webdriverwait
from selenium.webdriver.support import expected_conditions as ec
from bs4 import beautifulsoup
import time

def simulate_browser_operation():
    # 1. 初始化浏览器
    driver = webdriver.chrome()
    driver.maximize_window()
    target_url = "https://www.baidu.com"
    
    try:
        # 2. 访问网页
        driver.get(target_url)
        print(f"已访问:{target_url}")
        
        # 3. 显式等待搜索框,输入关键词并提交
        wait = webdriverwait(driver, 10)
        search_input = wait.until(
            ec.element_to_be_clickable((by.id, "kw")),
            message="超时:搜索框未加载完成"
        )
        search_input.send_keys("selenium 模拟浏览器操作 实战")
        search_input.send_keys(keys.enter)
        print("已提交搜索,等待结果加载")
        time.sleep(3)
        
        # 4. 模拟滚动页面,查看更多结果
        driver.execute_script("window.scrollto(0, 1000);")
        print("已滚动到搜索结果中部")
        time.sleep(2)
        
        # 5. 获取页面源码,提取第一条结果标题
        html_source = driver.page_source
        soup = beautifulsoup(html_source, "lxml")
        first_result_title = soup.find("h3", class_="t").get_text(strip=true)
        print(f"\n第一条搜索结果标题:{first_result_title}")
    
    except exception as e:
        print(f"操作过程中出现错误:{e}")
    
    finally:
        # 6. 关闭浏览器
        time.sleep(2)
        driver.quit()
        print("\n浏览器已关闭,操作流程结束")

if __name__ == "__main__":
    simulate_browser_operation()

七、常见问题与解决办法

  1. nosuchelementexception(未找到元素):① 检查定位表达式(id、xpath)是否正确;② 页面未加载完成,替换为显式等待;③ 元素在 iframe 中,需先切换:driver.switch_to.frame(iframe_element)
  2. 驱动与浏览器版本不匹配:下载与浏览器大版本一致的驱动(如 chrome 119.x 对应 chromedriver 119.x),避免过新或过旧。
  3. 点击操作无响应:① 元素被遮挡(如广告弹窗),先关闭弹窗;② 元素不可点击,等待 ec.element_to_be_clickable() 条件满足。
  4. 中文输入乱码:selenium 4.x 已良好支持中文,确保浏览器编码为 utf-8,直接使用 send_keys() 传入中文即可。

以上就是python使用selenium模拟浏览器操作的完整指南的详细内容,更多关于python selenium模拟浏览器操作的资料请关注代码网其它相关文章!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2026  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com