अनुरोध - त्रुटियों के साथ काम करना
यह अध्याय चर्चा करेगा कि Http अनुरोध पुस्तकालय के साथ काम करते समय आने वाली त्रुटियों से कैसे निपटें। सभी संभावित मामलों के लिए त्रुटियों का प्रबंधन करना हमेशा एक अच्छा अभ्यास होता है।
त्रुटि अपवाद
अनुरोध मॉड्यूल निम्न प्रकार की त्रुटि अपवाद देता है -
ConnectionError- कनेक्शन की त्रुटि होने पर इसे उठाया जाएगा। उदाहरण के लिए, नेटवर्क विफल, DNS त्रुटि इसलिए अनुरोध लाइब्रेरी कनेक्शन कनेक्शन को बढ़ा देगा।
Response.raise_for_status() - स्थिति कोड यानी 401, 404 के आधार पर यह आग्रह किए गए यूआरएल के लिए HTTPError बढ़ाएगा।
HTTPError - किए गए अनुरोध के लिए अमान्य प्रतिक्रिया के लिए यह त्रुटि उठाई जाएगी।
Timeout - अनुरोध किए गए URL के लिए समय-सीमा के लिए त्रुटियाँ।
TooManyRedirects - यदि सीमा अधिकतम पुनर्निर्देशन के लिए पार हो गई है तो यह बहुत अधिक त्रुटि को बढ़ाएगा।
उदाहरण
यहाँ टाइमआउट के लिए दिखाई गई त्रुटियों का एक उदाहरण है -
import requests
getdata =
requests.get('https://jsonplaceholder.typicode.com/users',timeout=0.001)
print(getdata.text)
उत्पादन
raise ConnectTimeout(e, request=request)
requests.exceptions.ConnectTimeout:
HTTPSConnectionPool(host='jsonplaceholder.ty
picode.com', port=443): Max retries exceeded with url: /users (Caused
by Connect
TimeoutError(<urllib3.connection.VerifiedHTTPSConnection object at
0x000000B02AD
E76A0>, 'Connection to jsonplaceholder.typicode.com timed out. (connect
timeout = 0.001)'))