Rutarelativa

Publicidad

Últimas anotaciones reducidas

  • Amnistía Pirata: Juega a Machinarium por solo 5 dólares Amnistía Pirata: Juega a Machinarium por solo 5 dólares

    Machinarium es uno de esos juegos sobresalientes que tanto nos gusta, y éste un buen movimiento para conseguir beneficios, pues han lanzado lo que ellos han llamado Amnistía Pirata. La Amnistía Pirata consiste en que los jugadores puedan jugar a Machinarium por solo 5 dólares (unos 3,90 €), ya que estiman que entre el 5% y el 15% de los que adquirieron el juego pagaron por él, y con este movimiento pretenden que aquellos jugadores que lo obtuvieron por diferentes vías (y los nuevos interesados) puedan comprarlo por un precio muy reducido.

    Incluye además la banda sonora del juego, y podéis jugar a una entretenida demo en la página oficial del juego para que, los que no lo conozcáis, podáis hacerlo y entrar en el mundo de Machinarium. La oferta es válida hasta el 12 de Agosto.

    [Amnistía Pirata: Juega a Machinarium por solo 5 dólares]

  • Video de una proyección 3D en Amsterdam Video de una proyección 3D en Amsterdam

    Este video se corresponde con una proyección 3D que hicieron en plena calle de Amsterdam, donde vemos que los elementos del escenario van sufriendo transformaciones dando como resultado un impresionante video con efecto 3D.

    Cuando te das cuenta que el edificio no está realmente ahí es cuando realmente impresiona.

    [Video de una proyección 3D en Amsterdam]

  • Curiosidades y Easter Eggs de Toy Story 3 [Video] Curiosidades y Easter Eggs de Toy Story 3 [Video]

    Tras ver Toy Story 3 y salir de la sala bastante encantado con la película me dispuse a buscar curiosidades y Easter Eggs de Toy Story 3 y he dado con este video de Youtube, que os dejo en el enlace final, que contiene algunos interesantes, y otros bastante exagerados.

    Entre dobladores curiosos, mensajes ocultos por los escenarios o cameos de otras de sus películas, el video nos va presentando lo que no pudimos ver mientras disfrutábamos de la última obra de Disney Pixar.

    [Video de Curiosidades y Easter Eggs de Toy Story 3]

Últimos comentarios

  • Avatar del usuario andres andres si pudieran especificar bien todos los pasos para la gente que no...
  • Avatar del usuario andres andres ese juego se pausa despues de las 40 horas que llevas jugadas...
  • Avatar del usuario Sergiocius Sergiocius De momento no has seguido los pasos para escribir un comentario...
  • Avatar del usuario raul suarez ladinez raul suarez ladinez !hola¡ quiero saber si segui los pasos correctamente y por lo...
  • Avatar del usuario Sergiocius Sergiocius Hola Boye, gracias por tu comentario. Vaya, ¡veo que eres de...
  • Avatar del usuario Boye Boye Hola! he llegado hoy de rebote al blog y me resulta bastante...
  • Avatar del usuario Jorge Jorge En Google Chrome no funciona lo de arrastrar a la barra de marcadores.
  • Avatar del usuario Alejandro Alejandro Juas... ya solo queda 1 mes y 10 días :S ¡Que verano mas largo!
  • Avatar del usuario Sura Sura Algunas fotos nos se pueden ver, yo no entiendo de esto pero al...
  • Avatar del usuario Sergiocius Sergiocius @Manuel Eso es difícil creo, ya que desde blogger cuando posteas...

Fans en Facebook de Ruta Relativa

Lo más comentado

Lo más visto

Post al azar

Curl en Python

(0)
12 / Diciembre / 2009
Curl en Python

Una de las cosas a las que me he enfrentado hace poco es la necesidad de hacer un script en Python que requería realizar peticiones a una página Web para obtener información. Para ello he necesitado usar la librería Pycurl que es la encargada de realizar las peticiones mediante Curl en Python. Como necesitaba llamar muchas veces a Curl he creado una función que me ayude en el proceso y se obtenga un código más limpio:

Función Curl para Python


import pycurl, StringIO, random, time

# Variables
dev_null = StringIO.StringIO()

# Function que realiza las conexiones curl
def curl(args):
	crCurl      = pycurl.Curl();
	sUrl        = args.get( 'url', None );
	sPostField  = args.get( 'post', None );
	ckCookie    = args.get( 'cookie', None );
	nHeader     = args.get( 'header', 0 );
	fcWrite     = args.get( 'write', dev_null.write );
	nTimeOut    = args.get( 'time_out', 30 );
	sAgent      = args.get( 'agent', 'Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.9.0.8) Gecko/2009032609 Firefox/3.0.8' );
	sReferer    = args.get( 'referer', '-' );
	aReferer    = args.get( 'aReferer', None );
	aProxys     = args.get( 'proxy', None );
	nProxyTunel = args.get( 'proxy_tunel', 1 );
	aHeader     = args.get( 'http_header', [ 'Accept: image/gif, image/x-bitmap, image/jpeg, image/pjpeg', 'Connection: Keep-Alive', 'Content-type: application/x-www-form-urlencoded;charset=UTF-8' ] );
	nFollow     = args.get( 'follow_location', 1 );
	sUserPasswd = args.get( 'user_passwd', None );

	if sUrl is None:
		return false;

    # Comprobamos si nos han pasado un array con referers para modificar el referer
	if aReferer is not None:
		# Referer aleatorio
		nRandomRf = random.randint( 0, len( aReferer ) - 1 );
		sReferer = aReferer[nRandomRf].replace( '[curl_text]', sReferer );

	# Opciones
	crCurl.setopt( crCurl.URL, sUrl );
	crCurl.setopt( crCurl.HEADER, nHeader );
	crCurl.setopt( crCurl.WRITEFUNCTION, fcWrite );
	crCurl.setopt( crCurl.HTTPHEADER, aHeader );
	crCurl.setopt( crCurl.CONNECTTIMEOUT, nTimeOut );
	crCurl.setopt( crCurl.REFERER, sReferer );
	crCurl.setopt( crCurl.USERAGENT, sAgent );
	crCurl.setopt( crCurl.FOLLOWLOCATION, nFollow );

	if sUserPasswd is not None:
		crCurl.setopt( crCurl.USERPWD, sUserPasswd );

	if aProxys is not None:
		# Usamos random para ir cambiando entre los diferentes proxys, asi no realizamos las peticiones siempre con el mismo proxy
		nRandom = random.randint( 0, len( aProxys ) - 1 );
		crCurl.setopt( crCurl.HTTPPROXYTUNNEL, nProxyTunel );
		crCurl.setopt( crCurl.PROXY, aProxys[nRandom] );

	if sPostField is not None:
		crCurl.setopt( crCurl.POST, 1 );
		crCurl.setopt( crCurl.POSTFIELDS, sPostField );

	if ckCookie is not None:
		crCurl.setopt( crCurl.COOKIEJAR, ckCookie );
		crCurl.setopt( crCurl.COOKIEFILE, ckCookie );

	crCurl.perform()

	# Comprobamos que la peticion es correcta, de no ser esperamos 10 segundos y volvemos a realizarla
	if crCurl.getinfo( crCurl.HTTP_CODE ) != 200:
		time.sleep(10);
		curl(args);

Argumentos para la función CURL

url: Dirección donde se realizará la petición por CURL.
post: Datos que se enviarán en una operación de tipo “HTTP POST”. Debe ser pasado como una cadena ‘para1 = val1 & para2 = val2 &…’.
cookie: Dirección donde se guardará la cookie, si se añade sólo el nombre se guardara en el directorio donde se ejecute el Script.
header: Mostrar la cabecera HTTP, por defecto 0.
write: Función que servirá para pintar el HTML devuelto. Por defecto None.
time_out: Tiempo de espera para la petición. Por defecto 30.
agent: Contenido de “User-Agent:” para la cabecera en una petición HTTP. Por defecto ‘Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.9.0.8) Gecko/2009032609 Firefox/3.0.8′.
referer: Contenido de “Referer:” para la cabecera en una petición HTTP. Por defecto ‘-’.
aReferer: Array con varios casos de ‘Referer:’. Podríamos añadir todos las referencias de Google, Yahoo, etc. Así mostraría el referido como si viniera de unos de estos buscadores. Por defecto None.
proxy: Array con varias IP de servidores Proxy. Por defecto None.
proxy_tunel: Túnel a través de los Proxy HTTP que hemos pasado como argumento. Por defecto 1.
http_header: Array con los campos para la petición HTTP. Por defecto [ 'Accept: image/gif, image/x-bitmap, image/jpeg, image/pjpeg', 'Connection: Keep-Alive', 'Content-type: application/x-www-form-urlencoded;charset=UTF-8']
nFollow: Seguir redirecciones HTTP. Por defecto 1
user_passwd: Usuario y contraseña que se usarán para la conexión, con el formato USUARIO:PASSWORD. Por defecto None.

Ejemplo petición Curl ocultando referido

curl( { 'url': 'http://www.tu-web-aqui.com',
'referer': 'buscando a curl',
'aReferer': ['http://www.google.es/search?hl=es&safe=active&q=[curl_text]'] } )

Ejemplo de Login con Curl

curl( {'url': 'URL_LOGIN',
'post': 'signin[username]=usuario&signin[password]=contraseña',
'cookie': 'cookie_curl'} )

Ejemplo para HTML con Curl

def pintar(response):
	print(response);

curl( { 'url': 'http://www.tu-web-aqui.com', 'write': pintar } )

Cambiar estado de Twitter mediante Curl

curl({ 'url'         : 'http://twitter.com/statuses/update.json',
       'post'        : 'status=Hola desde Python!',
	   'user_passwd' : 'usuario:password'
});

Una simple función Curl para python que nos ayudará a la hora de desarrollar scripts que necesiten realizar muchas peticiones.

Descargar curl para python

votar

Artículos relacionados

Sobre KeLDroX

288

Desarrollador en entornos web y Diseñador de profesión, muy activo, que busca siempre enfrentarse a retos cada vez más dificiles. Si un día no hago algo nuevo o no he superado alguna dificultad para mi es un día vacío. Cuento con dos titulaciones: Técnico en Explotación de Sistemas Informáticos y Técnico Superior en Desarrollo de Aplicaciones Informáticas. Fundé rutarelativa porque siempre quise tener un sitio en donde compartir mis experiencias profesionales y a los problemas que me enfrento día a día en el ámbito profesional.

Sigue a Ruta Relativa

Trackback en Curl en Python

Hasta el momento el artículo Curl en Python no tiene Trackbacks.

Comentarios en Curl en Python

Hasta el momento el artículo Curl en Python no tiene comentarios, sé el primero en comentar en él.

Escribir comentario en Curl en Python

¡Tu opinión nos interesa!. Escribe tu opinión lo más clara posible para que todos podamos entenderla, evita el spam, comentarios ofensivos, etc. ya que serán eliminados. Tu opinión sera moderada antes de ser publicada, por lo que su aparición en la web puede tardar unos minutos. Si deseáis ponerse en contacto para sugerencias o críticas podéis hacerlo desde el formulario de contacto.

Sigue a rutarelativa en twitter
Editores de Ruta Relativa
Avatar del editor KeLDroX KeLDroX Desarrollador en entornos web y Diseñador de profesión, muy activo, que busca siempre enfrentarse a retos cada vez más dificiles. Si un día no hago algo nuevo o no he superado alguna dificultad para mi es un día vacío. Cuento con dos titulaciones: Técnico en Explotación de Sistemas Informáticos y Técnico Superior en Desarrollo de Aplicaciones Informáticas. Fundé rutarelativa porque siempre quise tener un sitio en donde compartir mis experiencias profesionales y a los problemas que me enfrento día a día en el ámbito profesional.
Avatar del editor sergiocius sergiocius Soy un desarrollador en entornos web y escritorio, entusiasta y amante de mi trabajo del que cada día espero aprender algo nuevo. Tengo una titulación de Técnico Superior en Desarrollo de Aplicaciones Informáticas y actualmente curso el primer año de Carrera Universitaria con el poco tiempo que me deja el trabajo. Fundé rutarelativa porque quiero que mi esfuerzo y tiempo invertidos en aprender y poner en práctica algo le resulte útil y fácil a otro usuario, del mismo modo que yo aprendo y ahorro tiempo con la ayuda de los demás.