Publicidad
Anotaciones reducidas
La vida en un día: Película de un día en la Tierra
La vida en un día -Life in a day- es una película hecha por los propios usuarios de Youtube, que durante el día 24 de Julio del 2010 grabaron las cosas que pasaban en su vida durante ese día, y el director Kevin McDonald ha reunido en forma de película de un día en la Tierra.
De una hora y media de duración, veremos todo tipo de escenas en todas las partes del mundo, con una emotiva visión del mundo real tanto con sus cosas bellas y buenas, como con la más cruda visión del ser humano y su realidad.
Video: Las posibilidades de Kinect
Cuando oímos hablar de Kinect, no podemos evitar pensar en un "simple" aparato de detección de movimientos para videojuegos, y en cierto modo es así.
Lo bueno es que Microsoft ha lanzado una SDK de Kinect para que los usuarios puedan crear aplicaciones que exploten las capacidades del dispositivo, dando lugar a miles de ideas.
El siguiente video es al fin y al cabo con fines publicitarios, pero nos da que pensar acerca de las aún sin explotar posibilidades de Kinect. Disfrutadlo.
A Space Journey: Una excursión por el espacio en un video HD
A mi personalmente me encanta ver imágenes y fotografías del espacio, ver planetas lejanos, nebulosas o constelaciones. Es por eso que quiero compartir con ustedes A Space Journey, una excursión por el espacio en un video HD de Youtube, acompañado por una buena música y una ingente cantidad de fotografías espaciales.
Realmente merece la pena ver el video en pantalla completa y seleccionando que se reproduzca a 720p para disfrutar más del mismo.
[A Space Journey: Una excursión por el espacio en un video HD]
La historia de los Exploradores Web
Desde prácticamente los comienzos de Internet los Exploradores Web o Navegadores web nos han acompañado, haciendo las veces de herramientas indispensables para una navegación que a cada año que pasa se hace más cómoda y más intuitiva.
En Testking encuentro una imágen que contiene un gran esquema de la historia de los Exploradores Web desde el primer Nescape en 1994 hasta los navegadores modernos de este año 2011.
Una imágen interesante para conocer cuál ha sido la evolución en éste área.
Mapa de vuelos mundiales en 24 horas [Video]
Interesante video donde se muestra un mapa de vuelos mundiales en 24 horas, siendo cada punto amarillo la representación de un avión. Viendo el video podemos apreciar el impresionante afluente de vuelos en Estados Unidos y Asia, pero sobre todo la gran cantidad de vuelos en Estados Unidos.
Últimos comentarios
Fans en Facebook de Ruta Relativa
Lo más comentado
Lo más visto
Post al azar
XBox 360 Elegant Edition: Así es como debería haber sido
Publicado por sergiocius el día 26/11/2009Guardado en Geek,Videojuegos
Calientamanos recargable por USB
Publicado por sergiocius el día 03/12/2009Guardado en Gadgets,Geek
Fotografía: Como sería Fallout en el mundo real
Publicado por sergiocius el día 29/01/2010Guardado en Fotografía,Videojuegos
Contactable: Plugin para wordpress para feedback y contacto
Publicado por sergiocius el día 24/06/2010Guardado en Plugins
Pelicula de Mega Man
Publicado por sergiocius el día 08/02/2010Guardado en Cine,Videojuegos
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:
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);
| 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. |
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]'] } )
curl( {'url': 'URL_LOGIN',
'post': 'signin[username]=usuario&signin[password]=contraseña',
'cookie': 'cookie_curl'} )
def pintar(response):
print(response);
curl( { 'url': 'http://www.tu-web-aqui.com', 'write': pintar } )
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.
Artículos relacionados
Usar Google Translate con PHP y Python
Publicado por sergiocius el día 28/06/2010Guardado en Desarrollo
Mozilla Firefox no carga el CSS
Publicado por sergiocius el día 14/03/2011Guardado en CSS,Desarrollo
Eliminar marco de Google Imágenes y no perder ninguna visita
Publicado por sergiocius el día 01/12/2010Guardado en Desarrollo,Web
La Fail Whale de Twitter completamente en CSS
Publicado por sergiocius el día 28/07/2010Guardado en Anotaciones reducidas
Contactable: Plugin para wordpress para feedback y contacto
Publicado por sergiocius el día 24/06/2010Guardado en Plugins
Sobre 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.
Escribir comentario en Curl en Python