स्क्रेपी - अनुरोध और प्रतिक्रियाएं
विवरण
स्क्रेपी वेबसाइटों का उपयोग कर क्रॉल कर सकते हैं Request तथा Responseवस्तुओं। अनुरोध ऑब्जेक्ट सिस्टम के ऊपर से गुजरते हैं, मकड़ियों का उपयोग अनुरोध को निष्पादित करने के लिए करते हैं और प्रतिक्रिया ऑब्जेक्ट वापस आने पर अनुरोध पर वापस जाते हैं।
वस्तुओं का अनुरोध करें
अनुरोध ऑब्जेक्ट एक HTTP अनुरोध है जो एक प्रतिक्रिया उत्पन्न करता है। इसकी निम्न श्रेणी है -
class scrapy.http.Request(url[, callback, method = 'GET', headers, body, cookies, meta,
encoding = 'utf-8', priority = 0, dont_filter = False, errback])
निम्न तालिका अनुरोध वस्तुओं के मापदंडों को दिखाती है -
अनु क्रमांक | पैरामीटर और विवरण |
---|---|
1 | url यह एक स्ट्रिंग है जो URL अनुरोध को निर्दिष्ट करता है। |
2 | callback यह एक कॉल करने योग्य फ़ंक्शन है जो पहले पैरामीटर के रूप में अनुरोध की प्रतिक्रिया का उपयोग करता है। |
3 | method यह एक स्ट्रिंग है जो HTTP विधि अनुरोध को निर्दिष्ट करता है। |
4 | headers यह अनुरोध हेडर के साथ एक शब्दकोश है। |
5 | body यह एक स्ट्रिंग या यूनिकोड है जिसमें एक अनुरोध निकाय है। |
6 | cookies यह एक सूची है जिसमें अनुरोध कुकीज़ हैं। |
7 | meta यह एक शब्दकोश है जिसमें अनुरोध के मेटाडेटा के लिए मान शामिल हैं। |
8 | encoding यह एक स्ट्रिंग है जिसमें URL को एन्कोड करने के लिए उपयोग किया जाने वाला utf-8 एन्कोडिंग है। |
9 | priority यह एक पूर्णांक है जहां अनुसूचक अनुरोधों को संसाधित करने के लिए आदेश को परिभाषित करने के लिए प्राथमिकता का उपयोग करता है। |
10 | dont_filter यह एक बूलियन है जो निर्दिष्ट करता है कि अनुसूचक को अनुरोध को फ़िल्टर नहीं करना चाहिए। |
1 1 | errback यह एक कॉल करने योग्य कार्य है जिसे अनुरोध को संसाधित करते समय एक अपवाद कहा जाता है। |
कॉलबैक फ़ंक्शंस में अतिरिक्त डेटा पास करना
जब अनुरोध को इसके पहले पैरामीटर के रूप में डाउनलोड किया जाता है, तो अनुरोध के कॉलबैक फ़ंक्शन को कहा जाता है।
उदाहरण के लिए -
def parse_page1(self, response):
return scrapy.Request("http://www.something.com/some_page.html",
callback = self.parse_page2)
def parse_page2(self, response):
self.logger.info("%s page visited", response.url)
आप उपयोग कर सकते हैं Request.meta विशेषता, यदि आप कॉल करने योग्य कार्यों के लिए तर्कों को पास करना चाहते हैं और दूसरे कॉलबैक में उन तर्कों को प्राप्त करना चाहते हैं जो निम्न उदाहरण में दिखाए गए हैं -
def parse_page1(self, response):
item = DemoItem()
item['foremost_link'] = response.url
request = scrapy.Request("http://www.something.com/some_page.html",
callback = self.parse_page2)
request.meta['item'] = item
return request
def parse_page2(self, response):
item = response.meta['item']
item['other_link'] = response.url
return item
अनुरोध प्रसंस्करण में अपवादों को पकड़ने के लिए इरबैक्स का उपयोग करना
इरिटेब एक कॉल करने योग्य फ़ंक्शन है जिसे एक अनुरोध को संसाधित करते समय एक अपवाद कहा जाता है।
निम्न उदाहरण यह प्रदर्शित करता है -
import scrapy
from scrapy.spidermiddlewares.httperror import HttpError
from twisted.internet.error import DNSLookupError
from twisted.internet.error import TimeoutError, TCPTimedOutError
class DemoSpider(scrapy.Spider):
name = "demo"
start_urls = [
"http://www.httpbin.org/", # HTTP 200 expected
"http://www.httpbin.org/status/404", # Webpage not found
"http://www.httpbin.org/status/500", # Internal server error
"http://www.httpbin.org:12345/", # timeout expected
"http://www.httphttpbinbin.org/", # DNS error expected
]
def start_requests(self):
for u in self.start_urls:
yield scrapy.Request(u, callback = self.parse_httpbin,
errback = self.errback_httpbin,
dont_filter=True)
def parse_httpbin(self, response):
self.logger.info('Recieved response from {}'.format(response.url))
# ...
def errback_httpbin(self, failure):
# logs failures
self.logger.error(repr(failure))
if failure.check(HttpError):
response = failure.value.response
self.logger.error("HttpError occurred on %s", response.url)
elif failure.check(DNSLookupError):
request = failure.request
self.logger.error("DNSLookupError occurred on %s", request.url)
elif failure.check(TimeoutError, TCPTimedOutError):
request = failure.request
self.logger.error("TimeoutError occurred on %s", request.url)
Request.meta विशेष कुंजी
Request.meta विशेष कुंजी, स्क्रैपी द्वारा पहचाने जाने वाले विशेष मेटा कुंजी की एक सूची है।
निम्न तालिका अनुरोध की कुछ कुंजियाँ दिखाती है।
अनु क्रमांक | कुंजी और विवरण |
---|---|
1 | dont_redirect यह एक कुंजी है जब इसे सही पर सेट किया जाता है, तो प्रतिक्रिया की स्थिति के आधार पर अनुरोध को पुनर्निर्देशित नहीं करता है। |
2 | dont_retry यह एक कुंजी है जब इसे सही पर सेट किया जाता है, विफल अनुरोधों को पुनः प्राप्त नहीं करता है और इसे मिडलवेयर द्वारा अनदेखा किया जाएगा। |
3 | handle_httpstatus_list यह एक कुंजी है जो परिभाषित करता है कि प्रति-अनुरोध के आधार पर कौन से प्रतिक्रिया कोड की अनुमति दी जा सकती है। |
4 | handle_httpstatus_all यह एक कुंजी का उपयोग किसी भी प्रतिक्रिया कोड को सही करने के लिए अनुरोध के लिए करने के लिए किया जाता है । |
5 | dont_merge_cookies यह मौजूदा कुंजी के साथ विलय करने से बचने के लिए इसे सही पर सेट करने के लिए उपयोग की जाने वाली कुंजी है । |
6 | cookiejar यह एक कुंजी है जिसका उपयोग मकड़ी के प्रति कई कुकी सत्रों को रखने के लिए किया जाता है। |
7 | dont_cache यह HTTP नीति और प्रत्येक नीति पर प्रतिक्रिया से बचने के लिए उपयोग की जाने वाली एक कुंजी है। |
8 | redirect_urls यह एक कुंजी है जिसमें URL होते हैं जिसके माध्यम से अनुरोध पास होते हैं। |
9 | bindaddress यह निवर्तमान आईपी पते का आईपी है जिसका उपयोग अनुरोध करने के लिए किया जा सकता है। |
10 | dont_obey_robotstxt यह एक ऐसी कुंजी है जब इसे सही पर सेट किया जाता है, रोबो.टैक्स अपवर्जन मानक द्वारा निषिद्ध अनुरोधों को फ़िल्टर नहीं करता है, भले ही ROBOTSTXT_OBEY सक्षम हो। |
1 1 | download_timeout इसका उपयोग समय-समय पर (सेकंड में) प्रति स्पाइडर सेट करने के लिए किया जाता है, जिसके लिए डाउनलोडर समय से पहले इंतजार करेगा। |
12 | download_maxsize इसका उपयोग प्रति स्पाइडर अधिकतम आकार (बाइट्स में) सेट करने के लिए किया जाता है, जिसे डाउनलोडर डाउनलोड करेगा। |
13 | proxy अनुरोधों के उपयोग के लिए प्रॉक्सी प्रॉक्सी को HTTP प्रॉक्सी सेट करने के लिए प्रॉक्सी सेट किया जा सकता है। |
उपवर्गों का अनुरोध करें
अनुरोध वर्ग को उप-वर्ग करके आप अपनी स्वयं की कस्टम कार्यक्षमता को लागू कर सकते हैं। अंतर्निहित अनुरोध उपवर्ग इस प्रकार हैं -
औपचारिक वस्तुएँ
FormRequest वर्ग आधार अनुरोध का विस्तार करके HTML रूपों से संबंधित है। इसकी निम्न श्रेणी है -
class scrapy.http.FormRequest(url[,formdata, callback, method = 'GET', headers, body,
cookies, meta, encoding = 'utf-8', priority = 0, dont_filter = False, errback])
निम्नलिखित पैरामीटर है -
formdata - यह एक शब्दकोश है जिसमें एचटीएमएल फॉर्म डेटा होता है जिसे अनुरोध के निकाय को सौंपा जाता है।
Note - शेष पैरामीटर अनुरोध वर्ग के समान हैं और इसमें समझाया गया है Request Objects अनुभाग।
निम्नलिखित वर्ग विधियों द्वारा समर्थित हैं FormRequest अनुरोध विधियों के अलावा वस्तुएं -
classmethod from_response(response[, formname = None, formnumber = 0, formdata = None,
formxpath = None, formcss = None, clickdata = None, dont_click = False, ...])
निम्न तालिका उपरोक्त वर्ग के मापदंडों को दर्शाती है -
अनु क्रमांक | पैरामीटर और विवरण |
---|---|
1 | response यह HTML प्रतिक्रिया के HTML फॉर्म का उपयोग करके फॉर्म फ़ील्ड को पूर्व-पॉप्युलेट करने के लिए उपयोग की जाने वाली वस्तु है। |
2 | formname यह एक स्ट्रिंग है, जहां नाम विशेषता वाले फॉर्म का उपयोग किया जाएगा, यदि निर्दिष्ट किया गया है। |
3 | formnumber प्रतिक्रिया में कई रूप होने पर उपयोग किए जाने वाले रूपों का पूर्णांक होता है। |
4 | formdata यह ओवरराइड करने के लिए उपयोग किए जाने वाले फ़ॉर्म डेटा में फ़ील्ड का एक शब्दकोश है। |
5 | formxpath यह निर्दिष्ट करते समय एक स्ट्रिंग है, xpath से मेल खाते फॉर्म का उपयोग किया जाता है। |
6 | formcss यह निर्दिष्ट करने पर एक स्ट्रिंग है, सीएसएस चयनकर्ता से मेल खाने वाले फॉर्म का उपयोग किया जाता है। |
7 | clickdata यह क्लिक किए गए नियंत्रण का निरीक्षण करने के लिए उपयोग की जाने वाली विशेषताओं का एक शब्दकोश है। |
8 | dont_click फॉर्म से डेटा किसी भी तत्व को क्लिक किए बिना सबमिट किया जाएगा, जब यह सच हो जाएगा। |
उदाहरण
अनुरोध अनुरोध के कुछ उदाहरण निम्नलिखित हैं -
Using FormRequest to send data via HTTP POST
निम्न कोड दर्शाता है कि कैसे लौटना है FormRequest ऑब्जेक्ट जब आप अपने स्पाइडर में HTML फॉर्म POST डुप्लिकेट करना चाहते हैं -
return [FormRequest(url = "http://www.something.com/post/action",
formdata = {'firstname': 'John', 'lastname': 'dave'},
callback = self.after_post)]
Using FormRequest.from_response() to simulate a user login
आम तौर पर, वेबसाइटें उन तत्वों का उपयोग करती हैं जिनके माध्यम से यह पूर्व-आबादी वाले फॉर्म फ़ील्ड प्रदान करता है।
FormRequest.form_response() विधि का उपयोग तब किया जा सकता है जब आप चाहते हैं कि इन क्षेत्रों को स्क्रैप करते समय स्वचालित रूप से आबादी हो।
निम्न उदाहरण यह प्रदर्शित करता है।
import scrapy
class DemoSpider(scrapy.Spider):
name = 'demo'
start_urls = ['http://www.something.com/users/login.php']
def parse(self, response):
return scrapy.FormRequest.from_response(
response,
formdata = {'username': 'admin', 'password': 'confidential'},
callback = self.after_login
)
def after_login(self, response):
if "authentication failed" in response.body:
self.logger.error("Login failed")
return
# You can continue scraping here
प्रतिक्रियाएँ वस्तुएँ
यह HTTP प्रतिक्रिया का संकेत करने वाली एक वस्तु है जो मकड़ियों को संसाधित करने के लिए खिलाया जाता है। इसकी निम्न श्रेणी है -
class scrapy.http.Response(url[, status = 200, headers, body, flags])
निम्न तालिका प्रतिक्रिया वस्तुओं के मापदंडों को दर्शाती है -
अनु क्रमांक | पैरामीटर और विवरण |
---|---|
1 | url यह एक स्ट्रिंग है जो URL प्रतिसाद को निर्दिष्ट करता है। |
2 | status यह एक पूर्णांक है जिसमें HTTP स्थिति प्रतिक्रिया होती है। |
3 | headers यह एक शब्दकोश है जिसमें प्रतिक्रिया शीर्षलेख हैं। |
4 | body यह प्रतिक्रिया शरीर के साथ एक स्ट्रिंग है। |
5 | flags यह एक सूची है जिसमें प्रतिक्रिया के झंडे हैं। |
प्रतिक्रिया उपवर्ग
आप प्रतिक्रिया वर्ग को उप-वर्ग करके अपनी स्वयं की कस्टम कार्यक्षमता को लागू कर सकते हैं। अंतर्निहित प्रतिक्रिया उपवर्ग इस प्रकार हैं -
TextResponse objects
TextResponse ऑब्जेक्ट्स का उपयोग बाइनरी डेटा जैसे छवियों, ध्वनियों आदि के लिए किया जाता है, जिसमें आधार प्रतिक्रिया वर्ग को एनकोड करने की क्षमता होती है। इसकी निम्न श्रेणी है -
class scrapy.http.TextResponse(url[, encoding[,status = 200, headers, body, flags]])
निम्नलिखित पैरामीटर है -
encoding - यह एन्कोडिंग के साथ एक स्ट्रिंग है जिसका उपयोग किसी प्रतिक्रिया को एन्कोड करने के लिए किया जाता है।
Note - शेष पैरामीटर प्रतिक्रिया वर्ग के समान हैं और इसमें समझाया गया है Response Objects अनुभाग।
निम्न तालिका प्रतिक्रिया विधियों के अलावा TextResponse वस्तु द्वारा समर्थित विशेषताओं को दिखाती है -
अनु क्रमांक | विशेषता और विवरण |
---|---|
1 | text यह एक प्रतिक्रिया निकाय है, जहाँ response.text को कई बार एक्सेस किया जा सकता है। |
2 | encoding यह एक स्ट्रिंग है जिसमें प्रतिक्रिया के लिए एन्कोडिंग है। |
3 | selector यह पहली पहुंच पर त्वरित रूप से विशेषता है और लक्ष्य के रूप में प्रतिक्रिया का उपयोग करता है। |
निम्न तालिका प्रतिक्रिया विधियों के अलावा TextResponse वस्तुओं द्वारा समर्थित विधियों को दिखाती है -
अनु क्रमांक | विधि और विवरण |
---|---|
1 | xpath (query) यह TextResponse.selector.xpath (क्वेरी) का एक शॉर्टकट है। |
2 | css (query) यह TextResponse.selector.css (क्वेरी) का एक शॉर्टकट है। |
3 | body_as_unicode() यह एक प्रतिक्रिया निकाय है जो एक विधि के रूप में उपलब्ध है, जहाँ response.text को कई बार एक्सेस किया जा सकता है। |
HtmlResponse ऑब्जेक्ट्स
यह एक ऐसी वस्तु है जो HTML के मेटाफ्रेमस्पेकिव विशेषता को देखकर एन्कोडिंग और ऑटो-खोज का समर्थन करती है । इसके पैरामीटर रिस्पांस क्लास के समान हैं और रिस्पॉन्स ऑब्जेक्ट्स सेक्शन में समझाया गया है। इसकी निम्न श्रेणी है -
class scrapy.http.HtmlResponse(url[,status = 200, headers, body, flags])
XmlResponse ऑब्जेक्ट्स
यह एक ऐसी वस्तु है जो XML लाइन को देखकर एन्कोडिंग और ऑटो-खोज का समर्थन करती है। इसके पैरामीटर रिस्पांस क्लास के समान हैं और रिस्पॉन्स ऑब्जेक्ट्स सेक्शन में समझाया गया है। इसकी निम्न श्रेणी है -
class scrapy.http.XmlResponse(url[, status = 200, headers, body, flags])