स्क्रेपी - अपवाद
विवरण
अनियमित घटनाओं को अपवाद के रूप में संदर्भित किया जाता है। स्क्रेपी में, अपवादों को गायब करने जैसे कारणों से उठाया जाता है, आइटम पाइपलाइन से आइटम को छोड़ना, आदि। इसके बाद स्क्रेपी में उल्लिखित अपवादों और उनके आवेदन की सूची है।
ड्रॉप आइटम
आइटम पाइपलाइन किसी भी स्तर पर आइटम के प्रसंस्करण को रोकने के लिए इस अपवाद का उपयोग करता है। इसे इस प्रकार लिखा जा सकता है -
exception (scrapy.exceptions.DropItem)
CloseSpider
इस अपवाद का उपयोग कॉलबैक अनुरोध का उपयोग करके मकड़ी को रोकने के लिए किया जाता है। इसे इस प्रकार लिखा जा सकता है -
exception (scrapy.exceptions.CloseSpider)(reason = 'cancelled')
इसमें कारण (str) नामक पैरामीटर होता है जो समापन के कारण को निर्दिष्ट करता है।
उदाहरण के लिए, निम्न कोड इस अपवाद को दिखाता है -
def parse_page(self, response):
if 'Bandwidth exceeded' in response.body:
raise CloseSpider('bandwidth_exceeded')
IgnoreRequest
यह अपवाद शेड्यूलर या डाउनलोडर मिडलवेयर द्वारा किसी अनुरोध को अनदेखा करने के लिए उपयोग किया जाता है। इसे इस प्रकार लिखा जा सकता है -
exception (scrapy.exceptions.IgnoreRequest)
विन्यस्त नहीं
यह एक लापता कॉन्फ़िगरेशन स्थिति को इंगित करता है और एक घटक निर्माता में उठाया जाना चाहिए।
exception (scrapy.exceptions.NotConfigured)
यह अपवाद उठाया जा सकता है, यदि निम्न घटकों में से कोई भी अक्षम हो।
- Extensions
- आइटम पाइपलाइन
- डाउनलोडर बिचौलिए
- मकड़ी के मध्यवार
समर्थित नहीं
यह अपवाद तब उठाया जाता है जब कोई सुविधा या विधि समर्थित नहीं होती है। इसे इस प्रकार लिखा जा सकता है -
exception (scrapy.exceptions.NotSupported)