IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Python知识库 -> python爬虫第7章(1) -> 正文阅读

[Python知识库]python爬虫第7章(1)

selenium简介

能不能让我的程序连接到浏览器 . 让浏览器来完成各种复杂的操作, 我们只接受最终的结果

selenium: 自动化测试工具

可以: 打开浏览器. 然后像人一样去操作浏览器

程序员可以从selenium中直接提取网页上的各种信息

环境搭建:

? pip install selenium -i 清华源

? 下载浏览器驱动:https://npm.taobao.org/mirrors/chromedriver

? 把解压缩的浏览器驱动 chromedriver 放在python解释器所在的文件夹

看自己上一个博客安装的:https://blog.csdn.net/weixin_44953928/article/details/121444859

selenium的引入

from time import sleep
# 让selenium启动谷歌浏览器
from selenium.webdriver import Chrome

#1.创建浏览器对象

web=Chrome()

#2.打开一个网址

web.get("https://www.baidu.com/")

print(web.title)

sleep(5)
#关闭打开的页面
web.quit()

selenium的简单操作(1)

from time import sleep
from selenium.webdriver import Chrome
from selenium.webdriver.common.keys import Keys


web=Chrome()

web.get('https://lagou.com/')

# 找到某个元素. 点击它
el=web.find_element_by_xpath('//*[@id="changeCityBox"]/p[1]/a')  #按钮
el.click() #点击

sleep(1)  # 让浏览器缓一会儿

# 找到输入框. 输入python  =>  输入回车/点击搜索按钮
search=web.find_element_by_xpath('//*[@id="search_input"]').send_keys("python",Keys.ENTER) # Keys.ENTER是回车

sleep(1)

# 查找存放数据的位置. 进行数据提取
# 找到页面中存放数据的所有的div
div_list = web.find_elements_by_xpath('//*[@id="jobList"]/div[1]/div')      #注意elements,要不然element只能获取一个元素
for div in div_list:

    name=div.find_element_by_xpath('./div[1]/div[1]/div[1]/a').text
    job_price=div.find_element_by_xpath('./div[1]/div[1]/div[2]/span').text
    print(name,job_price)

sleep(1)
#关闭打开的页面
web.quit()
from selenium import webdriver
from lxml import etree
from time import sleep


bro=webdriver.Chrome(executable_path='./chromedriver')
bro.get('https://www.taobao.com/')

# page_text=bro.page_source
# #数据解析
# tree=etree.HTML(page_text)

#标签定位
search_input=bro.find_element_by_id('q')
#标签交互
search_input.send_keys('Iphone')

#执行一组js程序
bro.execute_script('window.scrollTo(0,document.body.scrollHeight)') #x向下滚动一平幕
sleep(2)

#点击搜索按钮
btn=bro.find_element_by_css_selector('.btn-search')  #这里填写的是class的属性值
btn.click()

selenium的简单操作(1)

from time import sleep
from selenium.webdriver import Chrome
from selenium.webdriver.common.keys import Keys


web=Chrome()

web.get('https://lagou.com/')

# 找到某个元素. 点击它
el=web.find_element_by_xpath('//*[@id="changeCityBox"]/p[1]/a')  #按钮
el.click() #点击

sleep(1)  # 让浏览器缓一会儿

# 找到输入框. 输入python  =>  输入回车/点击搜索按钮
search=web.find_element_by_xpath('//*[@id="search_input"]').send_keys("python",Keys.ENTER) # Keys.ENTER是回车

sleep(1)

# 查找存放数据的位置. 进行数据提取
# 找到页面中存放数据的所有的div
div_list = web.find_elements_by_xpath('//*[@id="jobList"]/div[1]/div')      #注意elements,要不然element只能获取一个元素
for div in div_list:

    name=div.find_element_by_xpath('./div[1]/div[1]/div[1]/a').text
    job_price=div.find_element_by_xpath('./div[1]/div[1]/div[2]/span').text
    print(name,job_price)

sleep(1)
#关闭打开的页面
web.quit()
from selenium import webdriver
from lxml import etree
from time import sleep


bro=webdriver.Chrome(executable_path='./chromedriver')
bro.get('https://www.taobao.com/')

# page_text=bro.page_source
# #数据解析
# tree=etree.HTML(page_text)

#标签定位
search_input=bro.find_element_by_id('q')
#标签交互
search_input.send_keys('Iphone')

#执行一组js程序
bro.execute_script('window.scrollTo(0,document.body.scrollHeight)') #x向下滚动一平幕
sleep(2)

#点击搜索按钮
btn=bro.find_element_by_css_selector('.btn-search')  #这里填写的是class的属性值
btn.click()

窗口间的切换

from selenium.webdriver import Chrome
from selenium.webdriver.common.keys import Keys
from time import sleep

web = Chrome()

web.get('https://lagou.com/')

#点击X
web.find_element_by_id('cboxClose').click() #  =web.find_element_by_xpath('//*[@id="cboxClose"]').click()

sleep(1)
#输入后搜索
# search=web.find_element_by_xpath('//*[@id="search_input"]').send_keys("python",Keys.ENTER) # Keys.ENTER是回车
web.find_element_by_id('search_input').send_keys('python',Keys.ENTER)

sleep(1)

#进入到新页面
web.find_element_by_xpath('//*[@id="jobList"]/div[1]/div[1]/div[1]/div[1]/div[1]/a').click()

# 如何进入到进窗口中进行提取
# 注意, 在selenium的眼中. 新窗口默认是不切换过来的.
web.switch_to.window(web.window_handles[-1])      #,选项卡,打开最后一个窗口,-1是最后一个

# 在新窗口中提取内容
job_detail=web.find_element_by_xpath('//*[@id="job_detail"]/dd[2]/div').text
print(job_detail)

sleep(5)
# 关掉子窗口
web.close() #关闭窗口,但是爬虫视角还在关闭的窗口哪里

# 变更selenium的窗口视角. 回到原来的窗口中
web.switch_to.window(web.window_handles[0])     #把窗口视角从删除的那一页转移到第一页

iframe如何处理

from selenium.webdriver import Chrome
from selenium.webdriver.common.keys import Keys
import time
web = Chrome()

# 如果页面中遇到了 iframe如何处理
web.get("https://www.91mjw.cc/video/76-1-0.html")

# 处理iframe的话. 必须先拿到iframe. 然后切换视角到iframe . 再然后才可以拿数据
iframe=web.find_element_by_xpath('//*[@id="cciframe"]')
# 切换到iframe
web.switch_to.frame(iframe)

# web.switch_to.default_content()  # 切换回原页面

tx = web.find_element_by_xpath('').text
print(tx)

无头浏览器

from selenium.webdriver import Chrome
from selenium.webdriver.support.select import Select
from time import sleep
from selenium.webdriver.chrome.options import Options

# 准备好参数配置
opt = Options()
opt.add_argument("--headless")
opt.add_argument("--disbale-gpu")


web=Chrome(options=opt)      # 把参数配置设置到浏览器中
web.get("https://www.endata.com.cn/BoxOffice/BO/Year/index.html")

sleep(2)
# 定位到下拉列表
sel_el=web.find_element_by_xpath('//*[@id="OptionDate"]')
# 对元素进行包装, 包装成下拉菜单
sel=Select(sel_el)
# 让浏览器进行调整选项
for i in range(len(sel.options)):   # i就是每一个下拉框选项的索引位置
    sel.select_by_index(i)   # 按照索引进行切换
    sleep(2)
    table=web.find_element_by_xpath('//*[@id="TableList"]/table')
    print(table.text)    # 打印所有文本信息
    print("----------------------------------------------------------------")

print('运行完毕')
web.close()


# 如何拿到页面代码Elements(经过数据加载以及js执行之后的结果的html内容)
#web.page_source
print(web.page_source)

实现规避检测

#实现规避检测
from selenium.webdriver import ChromeOptions

#实现规避检测
option = ChromeOptions()
option.add_experimental_option('excludeSwitches', ['enable-automation'])

#如何实现让selenium规避被检测到的风险
bro=webdriver.Chrome(executable_path='./chromedriver',chrome_options=chrome_options,options=option)
————————————————
版权声明:本文为CSDN博主「weixin_44953928」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_44953928/article/details/121454826

按照索引

在这里插入图片描述

  Python知识库 最新文章
Python中String模块
【Python】 14-CVS文件操作
python的panda库读写文件
使用Nordic的nrf52840实现蓝牙DFU过程
【Python学习记录】numpy数组用法整理
Python学习笔记
python字符串和列表
python如何从txt文件中解析出有效的数据
Python编程从入门到实践自学/3.1-3.2
python变量
上一篇文章      下一篇文章      查看所有文章
加:2021-11-26 08:49:10  更:2021-11-26 08:51:26 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/3 3:08:40-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码