您好,登錄后才能下訂單哦!
小編給大家分享一下Python如何基于requests庫爬取網站信息,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
python的五大特點:1.簡單易學,開發程序時,專注的是解決問題,而不是搞明白語言本身。2.面向對象,與其他主要的語言如C++和Java相比, Python以一種非常強大又簡單的方式實現面向對象編程。3.可移植性,Python程序無需修改就可以在各種平臺上運行。4.解釋性,Python語言寫的程序不需要編譯成二進制代碼,可以直接從源代碼運行程序。5.開源,Python是 FLOSS(自由/開放源碼軟件)之一。
requests庫是一個簡介且簡單的處理HTTP請求的第三方庫
get()是獲取網頁最常用的方式,其基本使用方式如下
使用requests庫獲取HTML頁面并將其轉換成字符串后,需要進一步解析HTML頁面格式,這里我們常用的就是beautifulsoup4庫,用于解析和處理HTML和XML
下面這段代碼便是爬取百度的信息并簡單輸出百度的界面信息
import requests from bs4 import BeautifulSoup r=requests.get('http://www.baidu.com') r.encoding=None result=r.text bs=BeautifulSoup(result,'html.parser') print(bs.title) print(bs.title.text)
import requests from bs4 import BeautifulSoup #用來解決亂碼現象,所以編寫爬取信息的代碼最好帶上(輸出出現亂碼或者UnicodeEncodeError:'gbk'codec can't encode character) import io import sys sys.stdout = io.TextIOWrapper(sys.stdout.buffer,encoding='gb18030') #用來防止反爬取,可以了解一下 headers={"User-Agent" : "Mozilla/5.0 (Windows; U; Windows NT 5.1; zh-CN; rv:1.9.1.6)", "Accept" : "text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8", "Accept-Language" : "en-us", "Connection" : "keep-alive", "Accept-Charset" : "GB2312,utf-8;q=0.7,*;q=0.7" } #獲取51job網站的基本信息 r=requests.get('https://search.51job.com/list/000000,000000,0000,00,9,99,python,2,1.html?lang=c&stype=&postchannel=0000&workyear=99&cotype=99°reefrom=99&jobterm=99&companysize=99&providesalary=99&lonlat=0%2C0&radius=-1&ord_field=0&confirmdate=9&fromType=&dibiaoid=0&address=&line=&specialarea=00&from=&welfare=') r.encoding=r.apparent_encoding result=r.text bs=BeautifulSoup(result,'html.parser') print(bs.prettify()) u1=bs.find_all('u1',attrs={'class':'item_con_list'}) #這部分代碼便是我們爬取的目標,51job網站上關于python職業的薪資 print(len(u1)) li=bs.find_all('span',attrs={'class':'t4'}) for l in li: print(l.text)
上面這段代碼便是爬取51job網站上的與python相關職業的薪資
以上是“Python如何基于requests庫爬取網站信息”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。