2008-12-22 6 views

Respuesta

113

No del todo. La creación de un objeto Request no envía realmente la solicitud, y los objetos Request no tienen el método Read(). (También: read() está en minúscula). Todo lo que necesita hacer es pasar el Request como primer argumento al urlopen() y eso le dará su respuesta.

import urllib2 
request = urllib2.Request("http://www.google.com", headers={"Accept" : "text/html"}) 
contents = urllib2.urlopen(request).read() 
13

normalmente uso:

import urllib2 

request_headers = { 
"Accept-Language": "en-US,en;q=0.5", 
"User-Agent": "Mozilla/5.0 (Windows NT 10.0; WOW64; rv:40.0) Gecko/20100101 Firefox/40.0", 
"Accept": "text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8", 
"Referer": "http://thewebsite.com", 
"Connection": "keep-alive" 
} 

request = urllib2.Request("http://thewebsite.com", headers=request_headers) 
contents = urllib2.urlopen(request).read() 
print contents 
1

Al lado de las otras soluciones ya mencionadas, se puede usar add_header método.

Así que el ejemplo proporcionado @pantsgolem py habrá:

import urllib2 
request = urllib2.Request("http://www.google.com") 

request.add_header('Accept','text/html') 

##Show the header having the key 'Accept' 
request.get_header('Accept') 

response = urllib2.urlopen(request) 
response.read() 
Cuestiones relacionadas