首页 > 数据库 > Redis > 正文

如何用python实现爬取CSDN热门评论URL并存入redis

WBOY
发布: 2023-05-28 15:17:23
转载
856 人浏览过

一、配置webdriver

下载谷歌浏览器驱动,并配置好

import timeimport randomfrom PIL import Imagefrom selenium import webdriverfrom selenium.webdriver.common.by import Byfrom selenium.webdriver.support.ui import WebDriverWaitfrom selenium.webdriver.support import expected_conditions as ECif __name__ == '__main__':options = webdriver.ChromeOptions()options.binary_location = r'C:UsershhhAppDataLocalGoogleChromeApplication谷歌浏览器.exe'# driver=webdriver.Chrome(executable_path=r'D:360Chromechromedriverchromedriver.exe')driver = webdriver.Chrome(options=options)#以java模块为例driver.get('https://www.csdn.net/nav/java')for i in range(1,20):driver.execute_script("window.scrollTo(0, document.body.scrollHeight)")time.sleep(2)
登录后复制

二、获取URL

from bs4 import BeautifulSoupfrom lxml import etree 
html = etree.HTML(driver.page_source)# soup = BeautifulSoup(html, 'lxml')# soup_herf=soup.find_all("#feedlist_id > li:nth-child(1) > div > div > h2 > a")# soup_herftitle = html.xpath('//*[@id="feedlist_id"]/li/div/div/h2/a/@href')
登录后复制

可以看到,一下爬取了很多,速度非常快
如何用python实现爬取CSDN热门评论URL并存入redis

三、写入Redis

导入redis包后,配置redis端口和redis数据库,用rpush函数写入
打开redis如何用python实现爬取CSDN热门评论URL并存入redis

import redis
r_link = redis.Redis(port='6379', host='localhost', decode_responses=True, db=1)for u in title:print("准备写入{}".format(u))r_link.rpush("csdn_url", u)print("{}写入成功!".format(u))print('=' * 30, 'n', "共计写入url:{}个".format(len(title)), 'n', '=' * 30)
登录后复制

如何用python实现爬取CSDN热门评论URL并存入redis

大功告成!

在Redis Desktop Manager中可以看到,爬取和写入都是非常的快。
如何用python实现爬取CSDN热门评论URL并存入redis
要使用只需用rpop出栈就OK

one_url = r_link.rpop("csdn_url)")while one_url:print("{}被弹出!".format(one_url))
登录后复制

以上是如何用python实现爬取CSDN热门评论URL并存入redis的详细内容。更多信息请关注PHP中文网其他相关文章!

相关标签:
来源:yisu.com
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!