摘要:爬蟲實戰二爬取西刺代理的代理對于剛入門的同學來說,本次實戰稍微有點難度,但是簡單的爬取圖片文本之類的又沒營養,所以這次我選擇了爬取西刺代理的地址,爬取的代理也能在以后的學習中用到本次實戰用的主要知識很多,其中包括自動保存利用抓包工具獲取和匹
對于剛入門的同學來說,本次實戰稍微有點難度,但是簡單的爬取圖片、文本之類的又沒營養,所以這次我選擇了爬取西刺代理的ip地址,爬取的代理ip也能在以后的學習中用到
本次實戰用的主要知識很多,其中包括:
requests.Session()自動保存cookie
利用抓包工具獲取cookie;
BeautifulSoup和xpath匹配html文檔中的標簽
subprocess測試ip并獲取運行時間及匹配的丟包數
代碼如下:
""" 案例名稱:學習使用ip代理池 需求:從網上找一個代理ip的網站,然后獲取網站上的 100個ip,組成代理ip池,然后隨機抽取其中一個ip, 并對該ip進行連通性測試,如果該ip可以,我們可以將 該ip作為代理ip來使用 思路: 1,先獲取西刺代理網站上的ip(100) 2, 隨機抽取其中一個ip,并檢測其連通性 3,如果該ip可用,則可以作為代理ip使用 編碼: 測試: """ import requests from bs4 import BeautifulSoup from lxml import etree import subprocess as sp import random import re """ 函數說明:獲取代理ip網站的ip """ def get_proxys(page): #requests的Session()可以自動保存cookie, #不需要自己維護cookie內容 S = requests.Session() #目標網址的url target_url = "http://www.xicidaili.com/nn/%d" %page target_headers = { "Upgrade-Insecure-Requests": "1", "User-Agent": "Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.36", "Accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8", "Referer": "http://www.xicidaili.com/nn/", "Accept-Encoding": "gzip, deflate, sdch", "Accept-Language": "zh-CN,zh;q=0.8" } target_response = S.get(url=target_url, headers=target_headers) target_response.encoding = "utf-8" target_html = target_response.text # print(target_html) #解析數據(ip,port,protocol) bf1_ip_list = BeautifulSoup(target_html,"lxml") bf2_ip_list = BeautifulSoup(str(bf1_ip_list.find_all(id="ip_list")),"lxml") ip_list_info = bf2_ip_list.table.contents proxys_list = [] for index in range(len(ip_list_info)): if index % 2 == 1 and index != 1: dom = etree.HTML(str(ip_list_info[index])) ip = dom.xpath("http://td[2]") port = dom.xpath("http://td[3]") protocol = dom.xpath("http://td[6]") proxys_list.append(protocol[0].text.lower() + "#" + ip[0].text + "#" + port[0].text) return proxys_list """ 函數說明:檢測代理ip的連通性 參數: ip--代理的ip地址 lose_time--匹配的丟包數 waste_time--匹配平均時間 返回值: average_time--代理ip的平均耗時 """ def check_ip(ip, lose_time, waste_time): cmd = "ping -n 3 -w 3 %s" #執行命令 p = sp.Popen(cmd %ip, stdin=sp.PIPE, stdout=sp.PIPE, stderr=sp.PIPE, shell=True) #獲取返回結果并解碼 out = p.stdout.read().decode("GBK") lose_time = lose_time.findall(out) if len(lose_time) == 0: lose = 3 else: lose = int(lose_time[0]) #如果丟包數大于2,那么我們返回平均耗時1000 if lose > 2: #返回false(1000) return 1000 else: #平均時間 average = waste_time.findall(out) if len(average) == 0: return 1000 else: average_time = int(average[0]) #返回平均耗時 return average_time """ 函數說明:初始化正則表達式 返回值: lose_time--匹配丟包數 waste_time--匹配平均時間 """ def initpattern(): #匹配丟包數 lose_time = re.compile(u"丟失 = (d+)",re.IGNORECASE) #匹配平均時間 waste_time = re.compile(u"平均 = (d+)ms",re.IGNORECASE) return lose_time, waste_time if __name__ == "__main__": #初始化正則表達式 lose_time, waste_time = initpattern() #獲取ip代理 proxys_list = get_proxys(1) #如果平均時間超過200ms,則重新選取ip while True: #從100個ip中隨機選取一個ip作為代理進行網絡訪問 proxy = random.choice(proxys_list) split_proxy = proxy.split("#") #獲取ip ip = split_proxy[1] #檢查ip average_time = check_ip(ip, lose_time, waste_time) if average_time > 200: #去掉不能使用的ip proxys_list.remove(proxy) print("ip鏈接超時,重新獲取中...") else: break proxys_list.remove(proxy) proxys_dict = {split_proxy[0]:split_proxy[1] + ":" + split_proxy[2]} print("使用代理:", proxys_dict)
今天的代碼有點難以理解,但是要按照代碼步驟及規范理解起來并不難,小伙伴們加油,我自己也加油!
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/42021.html
摘要:返回結果如下,接下來我們便開始爬取西刺代理,首先我們打開瀏覽器查看網頁,并找到和端口元素的信息。爬取代理地址,代理的是西刺代理去掉可能重復的等待秒將要爬取頁數的爬取好后存入數組,然后再對其中的逐一測試。 有時候在網站看小說,會莫名跳出來一個疑似機器惡意爬取,暫時無法訪問這樣類似的網站提示,需要刷新一下或者輸入一個驗證碼才能重新進入,這樣的情況偶有發生,相信大家都有遇到過。出現這個現象的...
摘要:返回結果如下,接下來我們便開始爬取西刺代理,首先我們打開瀏覽器查看網頁,并找到和端口元素的信息。爬取代理地址,代理的是西刺代理去掉可能重復的等待秒將要爬取頁數的爬取好后存入數組,然后再對其中的逐一測試。 有時候在網站看小說,會莫名跳出來一個疑似機器惡意爬取,暫時無法訪問這樣類似的網站提示,需要刷新一下或者輸入一個驗證碼才能重新進入,這樣的情況偶有發生,相信大家都有遇到過。出現這個現象的...
摘要:爬取豆瓣閱讀提供方代碼中會有詳細的注釋關于也是在看教程和書以及視頻學習,純種小白哈士奇的那種用到的庫爬蟲庫正則模塊寫模塊時間模塊庫偽裝瀏覽器的固定寫法也可以再加加個代理,也可以不加直接使用自己的地址代理西刺代理通過正則獲取內容菜鳥 爬取豆瓣閱讀提供方 代碼中會有詳細的注釋 關于python也是在看教程和書以及視頻學習,純種小白(哈士奇的那種) 用到的庫 urllib ????-> ...
摘要:一時心血來潮,于是當時想,如果拿來分析知乎這個網站,會有什么效果呢。知乎并沒有公開,只能采取爬蟲手段。如此,大概率會觸發知乎反爬蟲系統,所以采取以下方法來回避這個問題代理池。但是,很多情況下知乎還是能通過你的請求得到你的真實。。 網站地址books.bigfacewo.com最近工作去了,感覺人也變懶了,一直想寫一些關于這個網站東西分享出來。慢慢寫吧。前情提要:對于大神來說,這個網站使...
閱讀 3337·2021-11-25 09:43
閱讀 3025·2021-10-15 09:43
閱讀 1978·2021-09-08 09:36
閱讀 2930·2019-08-30 15:56
閱讀 758·2019-08-30 15:54
閱讀 2697·2019-08-30 15:54
閱讀 2989·2019-08-30 11:26
閱讀 1260·2019-08-29 17:27