Menú

Mostrar Mensajes

Esta sección te permite ver todos los mensajes escritos por este usuario. Ten en cuenta que sólo puedes ver los mensajes escritos en zonas a las que tienes acceso en este momento.

Mostrar Mensajes Menú

Mensajes - 0x5d

#151
Un gusto poder 'enseñar' ! :D
#152
Cita de: Runex en  8 Abril 2012, 16:23 PM
Bueno es :D.

He estado mirando tus tutoriales y te agradecería que los explicases sin clases de por medio si es posible, implementar clases en tutoriales es bastante lioso :D.

De todas formas Qt4 parece bastante potente en cuanto a interfaces no? :)
Hola, buen día !
Pues la verdad para QT4 es necesario usar clases, pero bueno, enseguida te explico el código a mi forma :P:
Código (python) [Seleccionar]
from PyQt4 import QtCore, QtGui
import sys, urllib, re
No creo que sea necesario explicar eso :P
Código (python) [Seleccionar]

    self.setWindowTitle("Detectar campos de un formulario | 0x5d")

Le damos un titulo a nuestra ventana(self(el mismo form))
Código (python) [Seleccionar]
    self.resize(510,570)Le damos las dimensiones self.resize(ancho,altura)
Código (python) [Seleccionar]
    self.arbol = QtGui.QTreeWidget(self)Creamos el Objeto QTreeWidget(); al poner 'self' dentro indico que se insertará en el mismo formulario y no en otro.
Código (python) [Seleccionar]
    self.arbol.setGeometry(5,70,500,500)Le doy las propiedades de ubicación y ancho-alto. setGeometry(x,y,ancho,alto)
Código (python) [Seleccionar]
    self.label_url = QtGui.QLabel("URL/Host :", self).setGeometry(5,10,64,27)Creo un Label para insertar un mensaje en el formulario, seguido le doy propiedades de ubicación y dimensiones
Código (python) [Seleccionar]
    self.input_url = QtGui.QLineEdit(self)Creo el QLineEdit(); para poder escribir.
Código (python) [Seleccionar]
    self.input_url.setGeometry(73,10,430,27)Le doy dimensiones y ubicación al QLineEdit();
Código (python) [Seleccionar]
    self.boton = QtGui.QPushButton("Extraer campos del formulario",self)Creo un Botón
Código (python) [Seleccionar]
    self.boton.setGeometry(73,40,430,27)Le doy propiedades de ubicación y dimensión al botón
Código (python) [Seleccionar]
    self.connect(self.boton, QtCore.SIGNAL("clicked()"), self.extractor)Le digo al programa que al dar clic(QtCore.SIGNAL("clicked()")) en self.boton , nos dirija a la función def extractor()
Código (python) [Seleccionar]
    self.arbol.headerItem().setText(0,"Campos")Con esto señalo la cabecera del QTreeWidget(); que luego los elementos aparecerán abajo. En este caso "Campos" (como ves en la imagen anterior)

Código (python) [Seleccionar]
  def extractor(self):La función extractor que llamé desde self.connect()
Código (python) [Seleccionar]
    var = urllib.urlopen(str(self.input_url.text())).read()Con str(self.input_url.text()) Obtengo el texto insertado en el QLineEdit() y lo abrimos con urllib.urlopen
Código (python) [Seleccionar]
    datos_r = []
    for campos in re.findall("<input (.*)>",var):
      if "name" in campos.lower():
for cam in campos.split():
  if re.findall("name=(.*)",cam):
    datos_r.append(cam.replace('"',""))
    Con eso obtengo los campos input del sitio web insertado, es cosa de saber Python, nada que ver con QT4
Código (python) [Seleccionar]
for x,y in enumerate(datos_r):
      exec("primer_%s = QtGui.QTreeWidgetItem(self.arbol)"%x)
      exec("self.arbol.topLevelItem(%s).setText(0, \"%s\")"%(x,y.replace("name=","")))
Ahí es un poco más complicado el caso, puesto que para cada elemento a insertar en nuestro QTreeWidget(); Necesitamos una variable que contenga a este elemento. Uso for x,y enumerate(datos_r): para contabilizar cuantos campos encontró el programa y su valor. Que mediante el primer exec() creo una variable para cada elemento, quedando :
primer_0 = ...
primer_1 = ...
Pero dependiendo de cuanto elemento sea encontrado.
Posteriormente   
Código (python) [Seleccionar]
exec("self.arbol.topLevelItem(%s).setText(0, \"%s\")"%(x,y.replace("name=","")))self.arbol.topLevelItem(%s) será:
self.arbol.topLevelItem(0)
self.arbol.topLevelItem(1)
self.arbol.topLevelItem(2)
etc Dependiendo de cuanto elemento se encuentra.
Luego con .setText(); insertamos el valor en la posición indicada por el x que contámos con enumerate();
Código (python) [Seleccionar]

app = QtGui.QApplication(sys.argv)
form = aplica() # Instancia a la clase aplica()
form.show() # Mostramos el formulario que es aplica()
app.exec_() # Corremos la aplicación


Intenté ser lo más claro posible y explicar línea por línea jaja

Saludos !
#154
Hola, buen día !

Sigo con mis prácticas en Python + QT4. Posterior a esto seguiré con el tutorial que estuve escribiendo para RootCodes... En esta oportunidad he traspasado este código en consola ~&gt; [Python]Detectar formulario y campos de un sitio web a PyQT. Así aprovechando de utilizar QTreeWidget(); Para aprender a usarlo y a la vez que ustedes vean como se usa.

Un ScreenShot de la App :



Y el Código :
Código (python) [Seleccionar]

# -*- coding: utf-8 -*-
# Autor ~> JaAViEr|0x5d
# Sitio Web ~> http://www.rootcodes.com
# Twitter ~> @0x5d

from PyQt4 import QtCore, QtGui
import sys, urllib, re

class aplica(QtGui.QWidget):
  def __init__(self, parent=None):
    QtGui.QWidget.__init__(self, parent)
    self.setWindowTitle("Detectar campos de un formulario | 0x5d")
    self.resize(510,570)
    self.arbol = QtGui.QTreeWidget(self)
    self.arbol.setGeometry(5,70,500,500)
    self.label_url = QtGui.QLabel("URL/Host :", self).setGeometry(5,10,64,27)
    self.input_url = QtGui.QLineEdit(self)
    self.input_url.setGeometry(73,10,430,27)
    self.boton = QtGui.QPushButton("Extraer campos del formulario",self)
    self.boton.setGeometry(73,40,430,27)
    self.connect(self.boton, QtCore.SIGNAL("clicked()"), self.extractor)
    self.arbol.headerItem().setText(0,"Campos")

  def extractor(self):
    var = urllib.urlopen(str(self.input_url.text())).read()
    datos_r = []
    for campos in re.findall("<input (.*)>",var):
      if "name" in campos.lower():
for cam in campos.split():
  if re.findall("name=(.*)",cam):
    datos_r.append(cam.replace('"',""))
    #print "URL a enviar POST:",url_enviar.replace(">","")
    for x,y in enumerate(datos_r):
      exec("primer_%s = QtGui.QTreeWidgetItem(self.arbol)"%x)
      exec("self.arbol.topLevelItem(%s).setText(0, \"%s\")"%(x,y.replace("name=","")))
     
app = QtGui.QApplication(sys.argv)
form = aplica()
form.show()
app.exec_()


Fuente: http://rootcodes.com/pyqt4detectar-campos-de-un-formulario-web/

Saludos, Javier.
#155
Hola a todos !

Como le he vuelto a dar la vida a mi PC. Instalé el Debian de nuevo, no podía faltar instalar el amado QT4. Así que me propuse como práctica crear este mismo código Consola ~> [Python]Decimal a binario y su invero, que por cierto también pasé a la web ~> Binary Converter Online. Esta vez en PyQT4 primero les dejo el screenshot de como se ve:


Y Su código :
Código (python) [Seleccionar]

# -*- coding: utf-8 -*-
# Autor : 0x5d ~> JaAViEr
# Sitio Web ~> www.rootcodes.com
# Twitter ~> @0x5d

from PyQt4 import QtGui, QtCore
import sys

class testeo(QtGui.QWidget):
  def __init__(self, parent=None):
    QtGui.QWidget.__init__(self, parent)
    self.setWindowTitle("Bin to Dec | 0x5d")
    self.label_binario = QtGui.QLabel("Binario :", self).setGeometry(2,15,59,17)
    self.input_binario = QtGui.QLineEdit(self)
    self.input_binario.setGeometry(60,10,230,27)
    self.label_resultado = QtGui.QLabel("Resultado :", self).setGeometry(2,50,80,17)
    self.input_salida = QtGui.QLineEdit(self)
    self.input_salida.setGeometry(80,43,210,27)
    self.input_salida.setReadOnly(True)
    self.boton_limpiar = QtGui.QPushButton("Limpiar campos", self)
    self.boton_limpiar.setGeometry(1,75,140,27)
    self.boton_convertir = QtGui.QPushButton("Convertir", self)
    self.boton_convertir.setGeometry(145,75,140,27)
    self.connect(self.boton_limpiar, QtCore.SIGNAL("clicked()"), self.clear_inputs)
    self.connect(self.boton_convertir, QtCore.SIGNAL("clicked()"), self.conversor)
 
  def clear_inputs(self):
    self.input_binario.setText("")
    self.input_salida.setText("")
   
  def conversor(self):
    numero = str(self.input_binario.text())
    t = 0
    for i,h in zip(numero[::-1],range(0,len(numero))): t+=int(i)*2**int(h)
    self.input_salida.setText(str(t))
   
app = QtGui.QApplication(sys.argv)
form = testeo()
form.show()
app.exec_()

Y Decimal a Binario:

Código ~>:
Código (python) [Seleccionar]

# -*- coding: utf-8 -*-
# Autor : 0x5d ~> JaAViEr
# Sitio Web ~> www.rootcodes.com
# Twitter ~> @0x5d

from PyQt4 import QtGui, QtCore
import sys

class testeo(QtGui.QWidget):
  def __init__(self, parent=None):
    QtGui.QWidget.__init__(self, parent)
    self.setWindowTitle("Dec to Bin | 0x5d")
    self.label_binario = QtGui.QLabel("Decimal:", self).setGeometry(2,15,59,17)
    self.input_binario = QtGui.QLineEdit(self)
    self.input_binario.setGeometry(60,10,230,27)
    self.label_resultado = QtGui.QLabel("Resultado :", self).setGeometry(2,50,80,17)
    self.input_salida = QtGui.QLineEdit(self)
    self.input_salida.setGeometry(80,43,210,27)
    self.input_salida.setReadOnly(True)
    self.boton_limpiar = QtGui.QPushButton("Limpiar campos", self)
    self.boton_limpiar.setGeometry(1,75,140,27)
    self.boton_convertir = QtGui.QPushButton("Convertir", self)
    self.boton_convertir.setGeometry(145,75,140,27)
    self.connect(self.boton_limpiar, QtCore.SIGNAL("clicked()"), self.clear_inputs)
    self.connect(self.boton_convertir, QtCore.SIGNAL("clicked()"), self.conversor)
 
  def clear_inputs(self):
    self.input_binario.setText("")
    self.input_salida.setText("")
   
  def conversor(self):
    resto = []
    nuevo = [int(self.input_binario.text())]
    while nuevo[-1]!=0:
      resto.append(nuevo[-1]%2)
      nuevo.append(nuevo[-1]/2)
    s = ""
    for i in resto[::-1]: s+="%s"%i
    self.input_salida.setText(str(s))
   
app = QtGui.QApplication(sys.argv)
form = testeo()
form.show()
app.exec_()


Fuente : http://rootcodes.com/pyqt4binario-a-decimal-y-su-inverso/

Saludos, Javier.
#156
Acabo de enchular mi prompt:
Código (bash) [Seleccionar]

PS1="\[$(tput setaf 6)\]\w\[$(tput setaf 1)@$(tput setaf 3)Debian$(tput setaf 1) ~~> $(tput setaf 2)\]"

y pues mi aliases no tiene nada del otro mundo:
Código (bash) [Seleccionar]

alias www="cd /var/www"                                                                                                                       
alias casa="cd /home/jaavier"                                                                                                                 
alias f5="sudo apt-get update &&sudo apt-get upgrade"                                                                                         
alias c_alias="kate .bash_aliases"



Saludos, Javier.
#157
GNU/Linux / Re: Rj 45
19 Febrero 2012, 10:29 AM
Cita de: DanFire en 17 Febrero 2012, 14:19 PM
hola,
he innstalado la última versión de ubuntu en mi vieja torre pentium 4 y no detecta
la conexión por cable.
Me preguntaba si a alguien le ha pasado algo parecido o tiene la solución.

Gracias.
Hola, buen día.
Hoy instalé el KDE en mi Debian y pues tenía gnome... Y me encontré
con que no me detectaba la conexión tampoco, así que busqué el Widget Network Management
Y lo puse en el escritorio, di clic secundario y entré a Network Management Settings
Ahí pulsé el Botón de Añadir y luego solo di clic en "OK" , doble clic al ícono y solucioné mi problema :D

Espero sea eso y no problemas de controladores :D

Saludos.
#158
Scripting / Re: [Python]
19 Febrero 2012, 10:25 AM
Otra cosa...
No es necesario importart "os" solo para hacer una pausa.
En Python mejor utiliza "raw_input()", solo por limpieza en tu código.

PD: Así como el colega arriba usó el + para concatenar, puedes usar ,
Código (python) [Seleccionar]

print "Escribiste", var

Código (python) [Seleccionar]

print "Escribiste %s"%var

Son varias maneras :D
#159
Cita de: bichotg en 19 Febrero 2012, 09:23 AM
Los dos habéis repuesto de una manera clarísima y facilísima de entender, creo que me lie un poco con algo que vi para recorrer una lista o que se yo. jeje, es mi primer lenguaje y me cuesta un poco, pero soy constante :), he andado por varios foros preguntando siempre mis dudas de python, y de verdad que aqui es donde mejor lo explicais,

Muchas gracias!!!
No problem ! cualquier duda solo planteala ;)
#160
Mejor que cierren a rapidshare :-\