2011-08-23 20 views
8

Vorrei prendere il timeout del socket (preferibilmente in un'eccezione) ... except urllib.error.URLError: può prenderlo ma devo distinguere tra un collegamento morto e un timeout .... Se tolgo lo except urllib.error.URLError: il timeout presa non cattura e lo script termina con un errore socket.timeoutEccezione socket socket time

import urllib.request,urllib.parse,urllib.error 
import socket 
import http 
socket.setdefaulttimeout(0.1) 


try: 
    file2 = urllib.request.Request('http://uk.geforce.com/html://') 
    file2.add_header("User-Agent","Mozilla/5.0 (Windows; U; Windows NT 6.0; en-US) AppleWebKit/525.13 (KHTML, like Gecko) Chrome/0.2.149.29 Safari/525.13") 
    file3 = urllib.request.urlopen(file2).read().decode("utf8", 'ignore') 
except urllib.error.URLError: print('fail') 
except socket.error: print('fail') 
except socket.timeout: print('fail') 
except UnicodeEncodeError: print('fail') 
except http.client.BadStatusLine: print('fail') 
except http.client.IncompleteRead: print('fail') 
except urllib.error.HTTPError: print('fail') 

print('done') 

risposta

5
... 
except urllib.error.URLError, e: 
    print type(e.reason) 

vedrete <class 'socket.timeout'> ogni volta che c'è un timeout socket. È questo che vuoi?

Ad esempio:

try: 
    data = urllib2.urlopen("http://www.abcnonexistingurlxyz.com") 
except Exception,e: 
    print type(e.reason) 
... 
<class 'socket.timeout'> 
+1

Ho appena realizzato che hai contrassegnato la questione Python-3.x. Sfortunatamente, non ho accesso a Python 3. Il codice sopra dovrebbe funzionare per 2.x dove x> = 3. –