爬虫篇——selenium(webdriver)进行用户登录并爬取数据)

爬虫篇——selenium(webdriver)进行用户登录并爬取数据

摘要

本文主要介绍了如何通过selenium使用Chormedriver进行用户登录并爬取数据,使用过程中需注意合理使用selenium.webdriver.support.expected_conditions
selenium.webdriver.support.ui.WebDriverWait

(一)创建browser对象

chromedriver.exe的下载地址为:点此进行下载

from selenium import webdriver
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions
from selenium.webdriver.common import by
from selenium.webdriver.common.action_chains import ActionChains
from lxml import etree

class ChromeCrawl(object):

    def __init__(self):
  
        chrome_options = webdriver.ChromeOptions()
        prefs = {"profile.managed_default_content_settings.images": 2}
        chrome_options.add_experimental_option("prefs", prefs)
        chrome_options.add_experimental_option('excludeSwitches', ['enable-automation']) 
        chrome_options.add_argument('--headless')
        chrome_options.add_argument('--no-sandbox')
        chrome_options.add_argument('--disable-gpu')
        
        self.browser = webdriver.Chrome(executable_path="./tools/chromedriver.exe", chrome_options=chrome_options)
        self.browser.set_page_load_timeout(60)
        self.browser.set_script_timeout(60)
        self.wait = WebDriverWait(self.browser, 60)

(二)用户登录

    def login(self):
        username = "*****"
        passwd = "******"

        self.browser.get('https:********login')
        self.browser.implicitly_wait(60)
        
        elem = self.browser.find_element_by_id("username")
        elem.send_keys(username)
        
        elem = self.browser.find_element_by_id("password")
        elem.send_keys(passwd)
        
        button = self.wait.until(expected_conditions.element_to_be_clickable((by.XPATH, '//*****')))# 根据自己的网页进行设置
        ActionChains(self.browser).click(button).perform()
    
        self.wait.until(expected_conditions.presence_of_element_located((by.CLASS_NAME, '******')))

(三)数据爬取

	def crawl(self):
        self.browser.get('https:******')
        self.wait.until(expected_conditions.presence_of_element_located((by.CLASS_NAME, '******')))
        html = etree.HTML(self.browser.page_source)
        tmp = html.xpath('//*****')

by CyrusMay 2022 01 25

一生要有多少的辗转
才能走到幸福的彼岸
——————五月天(青空未来)——————

  • 6
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值