欧美一区二区三区,国内熟女精品熟女A片视频小说,日本av网,小鲜肉男男GAY做受XXX网站

有python感受嗎,請問像攜程網(wǎng)這種網(wǎng)站怎么爬取?

錢浩然2年前17瀏覽0評論

掃除運行Scrapy爬蟲程序的bug之后,現(xiàn)在便可以開始進行編寫爬蟲邏輯了。在正式開始爬蟲編寫之前,在這里介紹四種小技巧,可以方便我們操縱和調(diào)試爬蟲。

一、建立main.py文件,直接在Pycharm下進行調(diào)試

很多時候我們在使用Scrapy爬蟲框架的時候,如果想運行Scrapy爬蟲項目的話,一般都會想著去命令行中直接執(zhí)行命令“scrapycrawlcrawler_name”,其中crawler_name指的是爬蟲的名字,在一開始創(chuàng)建Scrapy爬蟲模板的時候就指定了的,而且在該爬蟲項目中具有唯一性。但是每次跑到命令行下去執(zhí)行,看交互的結(jié)果,有時候并不是很清晰,所以這里介紹一種方法,可以幫助大家提高開發(fā)效率,尤其是調(diào)試的時候更是顯得方便。

在與爬蟲項目的scrapy.cfg文件同級目錄下建立一個main.py文件,用于控制整個爬蟲項目的執(zhí)行。

在該文件夾中寫入的代碼見下圖。其中execute函數(shù)是內(nèi)嵌在scrapy中的,調(diào)用這個函數(shù)可以直接調(diào)用該Scrapy工程項目的爬蟲腳本,這個函數(shù)的執(zhí)行需要在爬蟲項目的父目錄下進行。而第7行代碼的意思就是獲取當前py文件的父目錄,省去我們直接復制路徑的精力和時間,同時也方便我們將該項目放到其他的平臺上去運行,不會報路徑的錯誤。execute函數(shù)里邊的參數(shù)其實就是將Scrapy爬蟲執(zhí)行命令拆分,然后分別以一個字符的方式放到了一個數(shù)組中。

之后我們直接運行這個main.py文件便可以調(diào)用Scrapy爬蟲程序了。

二、多用Debug進行調(diào)試,提高開發(fā)速度

相信用過Pycharm的小伙伴都看到過Debug這個東東,它的英文意思就是“小蟲子”,在Pycharm中的logo也是個小蟲子,像是七星瓢蟲一樣,不過很多小伙伴可能還沒有怎么用過,這里簡單的介紹給大家,希望大家日后可以多多用到,對于項目的調(diào)試十分有幫助。

在進行Debug調(diào)試之前,我們需要在我們想要調(diào)試的代碼左側(cè)進行打斷點,斷點一般是紅色的,打斷點的方式很簡單,只需要在代碼的左側(cè)點擊一下左鍵即可,如下圖所示。

斷點設(shè)置完成之后,便可以去main.py文件進行調(diào)試了。在main.py文件點擊右鍵,然后選擇“Debug‘main’”,如下圖所示。

之后爬蟲程序便開始進行調(diào)試,并且會返回一系列結(jié)果,如下圖所示,可以方便的進行拖拽查看。同時也會在爬蟲文件中以綠色的字體進行顯示爬蟲的結(jié)果,很漂亮。

如果想退出或者停止該調(diào)試,則點擊Pycharm上方選項卡的Run,然后點擊“Stop‘main’”即可,如下圖所示。

之后該爬蟲程序就會退出調(diào)試,恢復正常的Pycharm界面,如下圖所示。

三、設(shè)置網(wǎng)站robots.txt規(guī)則為False

一般的,我們在運用Scrapy框架抓取數(shù)據(jù)之前,需要提前到settings.py文件中,將“ROBOTSTXT_OBEY=True”改為ROBOTSTXT_OBEY=False。

在未改動之后settings.py文件中默認爬蟲是遵守網(wǎng)站的robots.txt規(guī)則的,如下圖所示。

如果遵守robots.txt規(guī)則的話,那么爬取的結(jié)果會自動過濾掉很多我們想要的目標信息,因此有必要將該參數(shù)設(shè)置為False,如下圖所示。

設(shè)置好robots.txt規(guī)則之后,我們便可以抓到更多網(wǎng)頁的信息。

四、利用Scrapyshell進行調(diào)試

通常我們要運行Scrapy爬蟲程序的時候會在命令行中輸入“scrapycrawlcrawler_name”,細心的小伙伴應該知道上篇文章中創(chuàng)建的main.py文件也是可以提高調(diào)試效率的,不過這兩種方法都是需要從頭到尾運行Scrapy爬蟲項目,每次都需要請求一次URL,效率十分低。運行過Scrapy爬蟲項目的小伙伴都知道Scrapy運行的時候相對較慢,有時候因為網(wǎng)速不穩(wěn)定,根部就無法動彈。針對每次都需要運行Scrapy爬蟲的問題,這里介紹Scrapyshell調(diào)試方法給大家,可以事半功倍噢。

Scrapy給我們提供了一種shell模式,讓我們可以在shell腳本之下獲取整個URL對應的網(wǎng)頁源碼。在命令行中進行運行,其語法命令是“scrapyshellURL”,URL是指你需要抓取的網(wǎng)頁網(wǎng)址或者鏈接,如下圖所示。

該命令代表的意思是對該URL進行調(diào)試,當命令執(zhí)行之后,我們就已經(jīng)獲取到了該URL所對應的網(wǎng)頁內(nèi)容,之后我們就可以在該shell下進行調(diào)試,再也不用每次都執(zhí)行Scrapy爬蟲程序,發(fā)起URL請求了。

通過shell腳本這種方式可以極大的提高調(diào)試的效率,具體的調(diào)試方法同爬蟲主體文件中的表達式語法一致。舉個栗子,如下圖所示。

將兩個Xpath表達式所對應的選擇器放到scrapyshell調(diào)試的腳本下,我們可以很清楚的看到提取的目標信息,而且省去了每次運行Scrapy爬蟲程序的重復步驟,提高了開發(fā)效率。這種方式在Scrapy爬蟲過程中十分常用,而且也十分的實用,希望小伙伴們都可以掌握,并且積極主動的為自己所用。

關(guān)于Scrapy爬蟲項目運行和調(diào)試的部分小技巧先分享到這里,尤其是Debug調(diào)試和Scrapyshell調(diào)試極為常用,希望小伙伴們可以多多利用起來,讓其為自己的項目服務(wù),可以事半功倍噢~

原文鏈接:https://www.toutiao.com/i6684589023157027342/

原文鏈接:https://www.toutiao.com/i6679396332777505283/