栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

09爬虫-selenium实例

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

09爬虫-selenium实例

爬取某直播平台所有正在直播的房间信息
from selenium import webdriver
from selenium.webdriver.common.by import By
import time

class Douyu(object):
    def __init__(self):
    	#设置url	
        self.url="https://www.douyu.com/directory/all"
        #创建浏览器driver对象
        self.driver=webdriver.Chrome()

    def parse_data(self):
    	#睡眠三秒后再获取元素列表,否则元素还没加载出来就获取了会报错
        time.sleep(3)
        room_list=self.driver.find_elements(By.XPATH,'//*[@id="listAll"]/section[2]/div[2]/ul/li/div')
        print(len(room_list))
        data_list=[]
        #循环遍历元素列表,从每个元素中取出需要的数据进行保存
        for room in room_list:
            temp = {}
            temp['title']=room.find_element(By.XPATH,'./a/div[2]/div[1]/h3').text
            temp['type']=room.find_element(By.XPATH,'./a/div[2]/div[1]/span').text
            temp['owner']=room.find_element(By.XPATH,'./a[1]/div[2]/div[2]/h2').text
            temp['num']=room.find_element(By.XPATH,'./a[1]/div[2]/div[2]/span').text
       
            data_list.append(temp)
        return data_list
        
	#循环打印出列表中的每个词典
    def save_data(self, data_list):
        for data in data_list:
            print(data)

    def run(self):
        self.driver.get(self.url)
        while True:
            # parse
            data_list = self.parse_data()
            # save
            self.save_data(data_list)
            # next
            try:
            	#执行js语法,让滚轮往下滑动
                self.driver.execute_script('scrollTo(0,1000000)')
                #找下一页的元素,并点击
                el_next = self.driver.find_element(By.XPATH,'//*[contains(text(),"下一页")]')
                el_next.click()
            except:
                break

if __name__ == '__main__':
    dy=Douyu()
    dy.run()
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/876032.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号