scrapy中的spider傳參實現(xiàn)增量的方法
有時候需要根據(jù)項目的實際需求向spider傳遞參數(shù)來控制spider的運行方式。
比如說,1.根據(jù)用戶提交的url來控制spider爬取的網(wǎng)站。2.根據(jù)需求增量爬取數(shù)據(jù)。
今天就寫一個增量(augmenter)的方式:
Spider參數(shù)通過 crawl 命令的 -a 選項來傳遞,比如:
scrapy crawl xxx -a augmenter=xxxxxx
注:augmenter=不為空
1.首先在spider里添加

注:在網(wǎng)上也看了不少的博客,最后發(fā)現(xiàn)*args, **kwargs這兩個必須加上,要不然會出現(xiàn)bug,不信的話可以試試哦!
如果想減少代碼量的話,可以寫到類里面去繼承!那這樣的話,spider里面就不要在寫了?。。∫蝗痪筒黄鹱饔昧耍。?!
還有
super(eval(self.__class__.__name__), self).__init__(*args, **kwargs)
這里的eval()獲取的是類名,這樣寫必須是最后一個是你要的類名,中間有繼承什么的,就會出錯!或者直接把類名粘過來!
2.spider實現(xiàn)方式:


這樣就實現(xiàn)了簡單的增量!增量的方式有很多,常見的:時間、計數(shù)、爬取特定的幾頁!
選擇自己需要的增量方式寫在這個parse_augmenter()里面,
這樣需要從頭開始run和增量run就不受影響!
到此這篇關于scrapy中的spider傳參實現(xiàn)增量的方法的文章就介紹到這了,更多相關scrapy spider傳參增量內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
解決Django提交表單報錯:CSRF token missing or incorrect的問題
這篇文章主要介紹了解決Django提交表單報錯:CSRF token missing or incorrect的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-03-03

