詳解用python實(shí)現(xiàn)爬取CSDN熱門評(píng)論URL并存入redis
下載谷歌瀏覽器驅(qū)動(dòng),并配置好
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’)
可以看到,一下爬取了很多,速度非常快

導(dǎo)入redis包后,配置redis端口和redis數(shù)據(jù)庫(kù),用rpush函數(shù)寫入打開(kāi)redis

import redisr_link = redis.Redis(port=’6379’, host=’localhost’, decode_responses=True, db=1)for u in title: print('準(zhǔn)備寫入{}'.format(u)) r_link.rpush('csdn_url', u) print('{}寫入成功!'.format(u))print(’=’ * 30, ’n’, '共計(jì)寫入url:{}個(gè)'.format(len(title)), ’n’, ’=’ * 30)

大功告成!
在Redis Desktop Manager中可以看到,爬取和寫入都是非常的快。

要使用只需用rpop出棧就OK
one_url = r_link.rpop('csdn_url)')while one_url: print('{}被彈出!'.format(one_url))
到此這篇關(guān)于詳解用python實(shí)現(xiàn)爬取CSDN熱門評(píng)論URL并存入redis的文章就介紹到這了,更多相關(guān)python爬取URL內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. 詳解Android studio 動(dòng)態(tài)fragment的用法2. 編程語(yǔ)言PHP在Web開(kāi)發(fā)領(lǐng)域的優(yōu)勢(shì)在哪?3. Spring Boot和Thymeleaf整合結(jié)合JPA實(shí)現(xiàn)分頁(yè)效果(實(shí)例代碼)4. Android如何加載Base64編碼格式圖片5. 什么是python的自省6. 解決Android studio xml界面無(wú)法預(yù)覽問(wèn)題7. 基于android studio的layout的xml文件的創(chuàng)建方式8. 圖文詳解vue中proto文件的函數(shù)調(diào)用9. Springboot Druid 自定義加密數(shù)據(jù)庫(kù)密碼的幾種方案10. Vuex localStorage的具體使用

網(wǎng)公網(wǎng)安備