「Python」Selenium

基本使用

  1. 导入:from selenium import webdriver
  2. 创建浏览器操作对象:browser = webdriver.Chrome()
  3. 访问网站
python 复制代码
# 访问网站
url = 'https://www.jd.com'
browser.get(url)
python 复制代码
"""
selenium基本使用

Author:binxin
Date:2023/11/29 14:42
"""
# 导入
from selenium import webdriver

# 创建浏览器操作对象
browser = webdriver.Chrome()

# 访问网站
url = 'https://www.jd.com'
browser.get(url)

# page_source获取网页源码
content = browser.page_source
print(content)

元素定位

  1. 导入:from selenium.webdriver.common.by import By
python 复制代码
inputTag = driver.find_element(By.ID, "value")

inputTag = driver.find_element(By.CLASS_NAME, "value")

inputTag = driver.find_element(By.NAME, "value")

inputTag = driver.find_element(By.TAG_NAME, "value")

inputTag = driver.find_element(By.XPATH, "value")

inputTag = driver.find_element(By.CSS_SELECTOR, "value")
python 复制代码
"""
selenium 元素定位
Author:binxin
Date:2023/11/29 15:05
"""
from selenium import webdriver
from selenium.webdriver.common.by import By

browser = webdriver.Chrome()

url = 'https://www.baidu.com'

browser.get(url)

# 元素定位

# 根据ID找到对象
# button = browser.find_element(By.ID,'su')

# 根据标签属性的属性值获取对象
# button = browser.find_element(By.NAME, 'wd')

# 根据xpath语句获取对象
# button = browser.find_element(By.XPATH, '//input[@id="su"]')

# 根据标签名获取对象
# button = browser.find_element(By.TAG_NAME, 'input')

# 使用bs4的语法获取对象
# button = browser.find_element(By.CSS_SELECTOR, '#su')

button = browser.find_element(By.LINK_TEXT, '新闻')
print(button)

元素信息

  1. 获取元素属性:.get_attribute('class')
  2. 获取元素文本:.txt
  3. 获取标签名:.tag_name
python 复制代码
"""
元素信息

Author:binxin
Date:2023/11/29 16:31
"""
from selenium import webdriver
from selenium.webdriver.common.by import By

browser = webdriver.Chrome()

url = 'https://www.baidu.com'
browser.get(url)

input = browser.find_element(By.ID, 'su')

# 获取标签的属性
print(input.get_attribute('class'))
# 获取标签名
print(input.tag_name)

a = browser.find_element(By.LINK_TEXT, '新闻')
# 获取元素文本
print(a.text)

交互

  1. 点击:click()
  2. 输入:send_keys()
  3. 后退操作:browser.back()
  4. 前进操作:browser.forward()
  5. 模拟JS滚动:
python 复制代码
js='document.documentElement.scrollTop=100000'
browser.execute_script(js)  # 执行js代码
  1. 获取网页代码:page_source
  2. 退出:browser.quit()
python 复制代码
"""
selenium交互

Author:binxin
Date:2023/11/29 16:47
"""
from selenium import webdriver
from selenium.webdriver.common.by import By

browser = webdriver.Chrome()

url = 'https://www.baidu.com'

browser.get(url)

import time

time.sleep(2)

# 获取文本框对象
input = browser.find_element(By.ID, 'kw')

# 在文本框中输入周杰伦
input.send_keys('周杰伦')

time.sleep(2)

# 获取百度一下按钮
button = browser.find_element(By.ID, 'su')

# 点击按钮
button.click()

time.sleep(2)

# 滑动窗口到底部
js_bottom = 'document.documentElement.scrollTop=100000'
browser.execute_script(js_bottom)

time.sleep(2)

# 获取下一页按钮
next = browser.find_element(By.XPATH, '//a[@class="n"]')
# 点击下一页
next.click()

time.sleep(2)

# 返回上一页
browser.back()
time.sleep(2)

# 重新回到上一页
browser.forward()

time.sleep(3)

# 退出
browser.quit()

Chrome handless

  1. 基本代码
python 复制代码
from selenium import webdriver
from selenium.webdriver.chrome.options import Options

chrome_options = Options()
chrome_options.add_argument('--headless')
chrome_options.add_argument('--disable-gpu')

browser = webdriver.Chrome(options=chrome_options)
  1. 封装配置
python 复制代码
from selenium import webdriver
from selenium.webdriver.chrome.options import Options


def share_browser():
    chrome_options = Options()
    chrome_options.add_argument('--headless')
    chrome_options.add_argument('--disable-gpu')

    browser = webdriver.Chrome(options=chrome_options)

    return browser
python 复制代码
"""
Chrome handless

Author:binxin
Date:2023/11/30 11:06
"""
from selenium import webdriver
from selenium.webdriver.chrome.options import Options


def share_browser():
    chrome_options = Options()
    chrome_options.add_argument('--headless')
    chrome_options.add_argument('--disable-gpu')

    browser = webdriver.Chrome(options=chrome_options)

    return browser


# 封装调用
browser = share_browser()
url = 'http://www.baidu.com/'
browser.get(url)
browser.save_screenshot('baidu.png')
相关推荐
数据智能老司机2 小时前
精通 Python 设计模式——分布式系统模式
python·设计模式·架构
数据智能老司机3 小时前
精通 Python 设计模式——并发与异步模式
python·设计模式·编程语言
数据智能老司机3 小时前
精通 Python 设计模式——测试模式
python·设计模式·架构
数据智能老司机3 小时前
精通 Python 设计模式——性能模式
python·设计模式·架构
c8i3 小时前
drf初步梳理
python·django
每日AI新事件3 小时前
python的异步函数
python
这里有鱼汤4 小时前
miniQMT下载历史行情数据太慢怎么办?一招提速10倍!
前端·python
databook13 小时前
Manim实现脉冲闪烁特效
后端·python·动效
程序设计实验室14 小时前
2025年了,在 Django 之外,Python Web 框架还能怎么选?
python
倔强青铜三15 小时前
苦练Python第46天:文件写入与上下文管理器
人工智能·python·面试