自动点击网页脚本---selenium库使用

selenium操作各种浏览器
下载浏览器对应版本的chromedriver.exe放到 %systemroot%目录或其它可以被系统环境找到的目录下
复制代码
#coding:utf-8
from selenium import webdriver
from selenium.webdriver.chrome.options import Options
import time
#配置360浏览器地址开始
__browser_url = r'D:\Program Files\360Chrome\Chrome\Application\360chrome.exe' #浏览器目录地址
chrome_driver = "C:\Program Files (x86)\Google\Chrome\Application\chromedriver.exe" 
chrome_options = Options()
chrome_options.binary_location = __browser_url
#配置360浏览器地址结束
brower = webdriver.Chrome(chrome_driver,options=chrome_options)
#brower = webdriver.Firefox()
#brower = webdriver.IE()
brower.find_elements_by_......
复制代码

 

浏览器启用方式
启动Chrome浏览器:
from selenium import webdriver
browser = webdriver.Chrome()
browser.get('https://www.lidihuo.com/')
 
启动Firefox浏览器:
from selenium import webdriver
browser = webdriver.Firefox()
browser.get('https://www.lidihuo.com/')
 
启动IE浏览器:
from selenium import webdriver
browser = webdriver.Ie()
browser.get('https://www.lidihuo.com/')
添加浏览器参数add_argument
chrome_options.add_argument('--参数1 --参数2')
chrome_options.add_experimental_option('excludeSwitches', ['enable-logging']) #不输出console.log的日志内容到控制台
chrome_options.add_argument('--start-maximized') # 最大化运行(全屏窗口),不设置,取元素会报错
chrome_options.add_experimental_option('excludeSwitches', ['enable-automation']) #规避部分网站对selenium的检测
browser = webdriver.Chrome(options=chrome_options) #加载参数
 
具体可参见 https://peter.sh/experiments/chromium-command-line-switches/ ,该网站罗列了所有的参数。
设置代理
chrome_options.add_argument('--proxy-server=http://{ip}:{port}')
Headless方式启动
Headless Chrome 是 Chrome 浏览器的无界面形态,可以在不打开浏览器的前提下,使用所有 Chrome 支持的特性运行你的程序。相比于现代浏览器,Headless Chrome 更加方便测试 web 应用,获得网站的截图,做爬虫抓取信息等。相比于较早的 PhantomJS,SlimerJS 等,Headless Chrome 则更加贴近浏览器环境。
Headless Chrome 对Chrome版本要求:
官方文档中介绍,mac和linux环境要求chrome版本是59+,而windows版本的chrome要求是60+,同时chromedriver要求2.30+版本。
from selenium import webdriver
chrome_options = webdriver.ChromeOptions()
# 使用headless无界面浏览器模式
chrome_options.add_argument('--headless')
chrome_options.add_argument('--disable-gpu')
# 启动浏览器,获取网页源代码
browser = webdriver.Chrome(options=chrome_options)

 

加载配置启动浏览器
Selenium操作浏览器是不加载任何配置的,下面是关于加载Chrome配置的方法:
用Chrome地址栏输入chrome://version/,查看自己的“个人资料路径”,然后在浏览器启动时,调用这个配置文件,代码如下:
# coding=utf-8
from selenium import webdriver
option = webdriver.ChromeOptions()
# 设置成用户自己的数据目录
option.add_argument('--user-data-dir=C:\Users\Administrator\AppData\Local\Google\Chrome\User Data')
driver=webdriver.Chrome(options=option)
 
单独配置浏览器selenium驱动位置
chrome_driver = "C:\Program Files (x86)\Google\Chrome\Application\chromedriver.exe"
driver = webdriver.Chrome(chrome_driver, chrome_options=chrome_options)
 
而加载Firefox配置的方法有些不同:
打开Firefox点右上角设置>?(帮助)>故障排除信息>显示文件夹,打开后把路径复制下来就可以了
# coding=utf-8
from selenium import webdriver
# 配置文件地址
profile_directory = r'C:\Users\xxx\AppData\Roaming\Mozilla\Firefox\Profiles\1x41j9of.default'
# 加载配置配置
profile = webdriver.FirefoxProfile(profile_directory)
# 启动浏览器配置
driver = webdriver.Firefox(profile)

 

 
使用selenium控制已打开的浏览器
这里给出Google Chrome浏览器的解决方案。
我们可以利用Chrome DevTools协议。它允许客户检查和调试Chrome浏览器。
打开cmd,在命令行中输入命令:
chrome.exe --remote-debugging-port=9222 --user-data-dir="C:\selenum\AutomationProfile"
  • 对于-remote-debugging-port值,可以指定任何打开的端口。
  • 对于-user-data-dir标记,指定创建新Chrome配置文件的目录。它是为了确保在单独的配置文件中启动chrome,不会污染你的默认配置文件。
还有,不要忘了在环境变量中PATH里将chrome的路径添加进去。
此时会打开一个浏览器页面,我们输入百度网址,我们把它当成一个已存在的浏览器:
from selenium import webdriver
from selenium.webdriver.chrome.options import Options
 
chrome_options = Options()
chrome_options.add_experimental_option("debuggerAddress", "127.0.0.1:9222")
chrome_driver = "C:\Program Files (x86)\Google\Chrome\Application\chromedriver.exe"
driver = webdriver.Chrome(chrome_driver, chrome_options=chrome_options)
print(driver.title)

 

会发现打印出了 “百度一下,你就知道” 的网页标题。这样我们就实现了对一个已打开的浏览器的控制。
webdriver.chrome()
  • 其它
    • execute_script('js代码')
      • 需要先新建js代码,再执行
        • js='scrollTo(0,1000)' js滚动代码
    • switch_to_alert()
    • quit() 退出浏览器
  • 元素定位
    • 查找一个元素
      • find_element_by_id()
      • find_element_by_name()
      • find_element_by_link_text() 匹配全部文本
      • find_element_by_partial_link_text() 部分文本匹配
      • find_element_by_xpath()
      • find_element_by_class_name() 单类名用
      • find_element_by_tag_name()
      • find_element_by_css_selector() css通用
    • 查找一组元素
      • find_elements_by_id()
      • find_elements_by_name()
      • find_elements_by_link_text()
      • find_elements_by_partial_link_text()
      • find_elements_by_xpath()
      • find_elements_by_class_name()
      • find_elements_by_tag_name()
      • find_elements_by_css_selector()
        • class含有空格时解决方法
          • 直接包含空格的CSS属性定位大法
            • find_element_by_css_selector("[class='classname1 classname2']").send_keys("yoyo")
          • 或者在每个class前面加上点
            • find_element_by_css_selector('.dtb-style-1.table-dragColumns').click()
  • 元素操作方法
    • send_keys() 发送文本或按键
      • 发送回车键
        • 要想调用键盘按键操作需要引入 keys 包:
        • from selenium.webdriver.common.keys import Keys
        • 通过 send_keys()调用按键:
          • send_keys(Keys.ENTER)
        • 键盘组合键的用法:
          • # ctrl+a 全选输入框内容
          • send_keys(Keys.CONTROL,'a')
      • 发送文本
        • send_keys("你好吗")
    • click() 单击
    • clear() 清除对象内容
    • submit() 提交
    • text() 获取元素文本信息
  • 获取元素属性和文本
    • get_attribute()
      • innerHTML:会返回元素的内部 HTML, 包含所有的HTML标签。
      • textContent:获取 HTML 文本,需要注意的是 textContent 是 W3C 兼容的文字内容属性,不支持 IE 浏览器。
      • innerText:获取 HTML 文本,与 textContent 不同的是 innerText 不是 W3C DOM 的指定内容,不支持 FireFox 浏览器。
      • value:获取带有 value 属性的值。
    • get_property()
  • 浏览器操作
    • 将浏览器最大化显示
      • browser.maximize_window()
    • 将浏览器最小化显示
      • browser.minimize_window()
    • 浏览器设置窗口大小
      • 设置浏览器宽480、高800显示
        • browser.set_window_size(480, 800)
    • 浏览器前进后退
      • 前进
        • browser.forword()
      • 后退
        • browser.back()
  • 三种等待方式
    • 强制等待
      • time.sleep(秒)
        • 需要导入time包
    • 隐性等待
      • 通过添加 implicitly_wait() 方法就可以方便的实现智能等待;等待隐形等待是设置了一个最长等待时间,如果在规定时间内网页加载完成,则执行下一步,否则一直等到时间截止,然后执行下一步。
        • implicitly_wait(30) 智能等待30秒
      • 隐性等待对整个driver的周期都起作用,所以只要设置一次即可
    • 显性等待
      • WebDriverWait(driver, 超时时长, 调用频率, 忽略异常).until(可执行方法, 超时时返回的信息)
        • init
        • until
        • until_not
  • 多层框架定位
    • switch_to_frame
 
Xpath&Css定位方法速查表
  • 描述 Xpath Css
  • 直接子元素 //div/a div > a
  • 子元素或后代元素 //div//a div a
  • 以id定位 //div[@id='idValue']//a div#idValue a
  • 以class定位 //div[@class='classValue']//a div.classValue a
  • 同级弟弟元素 //ul/li[@class='first']/following- ul>li.first + li
  • 属性 //form/input[@name='username'] form input[name='username']
  • 多个属性 //input[@name='continue' and input[name='continue'][type='button
  • 第4个子元素 //ul[@id='list']/li[4] ul#list li:nth-child(4)
  • 第1个子元素 //ul[@id='list']/li[1] ul#list li:first-child
  • 最后1个子元素 //ul[@id='list']/li[last()] ul#list li:last-child
  • 属性包含某字段 //div[contains(@title,'Title')] div[title*="Title"]
  • 属性以某字段开头 //input[starts-with(@name,'user')] input[name^="user"]
  • 属性以某字段结尾 //input[ends-with(@name,'name')] input[name$="name"]
  • text中包含某字段 //div[contains(text(), 'text')] 无法定位
  • 元素有某属性 //div[@title] div[title]
  • 父节点 //div/.. 无法定位
  • 同级哥哥节点 //li/preceding-sibling::div[1] 无法定位
 
Python Webdriver Exception速查表
webdriver在使用过程中可能会出现各种异常,我们需要了解该异常并知道如何进行异常处理。
  • 异常 描述
  • WebDriverException 所有webdriver异常的基类,当有异常且不属于下列异常时抛出
  • InvalidSwitchToTargetException 下面两个异常的父类,当要switch的目标不存在时抛出
  • NoSuchFrameException 当你想要用switch_to.frame()切入某个不存在的frame时抛出
  • NoSuchWindowException 当你想要用switch_to.window()切入某个不存在的window时抛出
  • NoSuchElementException 元素不存在,一般由find_element与find_elements抛出
  • NoSuchAttributeException 一般你获取不存在的元素属性时抛出,要注意有些属性在不同浏览器里是有不同的属性名的
  • StaleElementReferenceException 指定的元素过时了,不在现在的DOM树里了,可能是被删除了或者是页面或iframe刷新了
  • UnexpectedAlertPresentException 出现了意料之外的alert,阻碍了指令的执行时抛出
  • NoAlertPresentException 你想要获取alert,但实际没有alert出现时抛出
  • InvalidElementStateException 下面两个异常的父类,当元素状态不能进行想要的操作时抛出
  • ElementNotVisibleException 元素存在,但是不可见,不可以与之交互
  • ElementNotSelectableException 当你想要选择一个不可被选择的元素时抛出
  • InvalidSelectorException 一般当你xpath语法错误的时候抛出这个错
  • InvalidCookieDomainException 当你想要在非当前url的域里添加cookie时抛出
  • UnableToSetCookieException 当driver无法添加一个cookie时抛出
  • TimeoutException 当一个指令在足够的时间内没有完成时抛出
  • MoveTargetOutOfBoundsException actions的move操作时抛出,将目标移动出了window之外
  • UnexpectedTagNameException 获取到的元素标签不符合要求时抛出,比如实例化Select,你传入了非select标签的元素时
  • ImeNotAvailableException 输入法不支持的时候抛出,这里两个异常不常见,ime引擎据说是仅用于linux下对中文/日文支持的时候
  • ImeActivationFailedException 激活输入法失败时抛出
  • ErrorInResponseException 不常见,server端出错时可能会抛
  • RemoteDriverServerException 不常见,好像是在某些情况下驱动启动浏览器失败的时候会报这个错
 
 
posted @   寂寞圣贤  阅读(942)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
点击右上角即可分享
微信分享提示