jueves, 29 de noviembre de 2012

Exportar a Excel desde ListView en Visual Basic


Tratando de exportar a Excel desde ListView en Visual Basic me puse a indagar la manera pero la mayoría de los foros solo escriben exportar desde DataGrid . Les dejo los pasos para realizar un exportación EXITOSA desde ListView…!!
exportar a excel desde Listview en VisualBasic 2010
exportar a excel desde Listview en VisualBasic 2010
exportar a excel desde Listview en VisualBasic 2010
exportar a excel desde Listview en VisualBasic 2010
exportar a excel desde Listview en VisualBasic 2010
exportar a excel desde Listview en VisualBasic 2010
exportar a excel desde Listview en VisualBasic 2010
exportar a excel desde Listview en VisualBasic 2010
exportar a excel desde Listview en VisualBasic 2010
exportar a excel desde Listview en VisualBasic 2010
exportar a excel desde Listview en VisualBasic 2010
exportar a excel desde Listview en VisualBasic 2010
Imports Microsoft.Office.Interop


exportar a excel desde Listview en VisualBasic 2010
exportar a excel desde Listview en VisualBasic 2010

 Private Sub Button3_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button3.Click
        Try
            Dim xla As New Microsoft.Office.Interop.Excel.Application()
          xla.Visible = True

            Dim wb As Microsoft.Office.Interop.Excel.Workbook = xla.Workbooks.Add(Microsoft.Office.Interop.Excel.XlSheetType.xlWorksheet)

            Dim ws As Microsoft.Office.Interop.Excel.Worksheet = DirectCast(xla.ActiveSheet, Microsoft.Office.Interop.Excel.Worksheet)

            Dim i As Integer = 1
            Dim j As Integer = 1
            Dim jj As Integer = ListView1.Columns.Count

            For rr = 0 To ListView1.Columns.Count - 1
                ws.Cells(i, j) = ListView1.Columns(rr).Text
                j = j + 1
            Next
            i = 2
            j = 1
            For Each comp As ListViewItem In ListView1.Items
                ws.Cells(i, j) = comp.Text.ToString()              
                For Each drv As ListViewItem.ListViewSubItem In comp.SubItems
                    ws.Cells(i, j) = drv.Text.ToString()
                    j += 1
                Next
                j = 1
                i += 1
            Next
        Catch ex As Exception
            MessageBox.Show(ex.Message)
        End Try
    End Sub


exportar a excel desde Listview en VisualBasic 2010
exportar a excel desde Listview en VisualBasic 2010
exportar a excel desde Listview en VisualBasic 2010
exportar a excel desde Listview en VisualBasic 2010
Fuente: http://paradageek.16mb.com/2012/06/exportar-a-excel-desde-listview-en-visual-basic/#&panel1-7

martes, 27 de noviembre de 2012

Instalar Apache, PHP, MySQL y phpMyAdmin en Ubuntu 12.04


 
 En esta entrada explicaremos como instalar Apache, phpMyAdmin, son software necesario para poder configurar un servidor web básico.
 Lo siguiente es la instalación más básica y menos segura de dichos programas, no recomendado para un servidor en producción.
 Hay unos niveles y protocolos de seguridad que se deberían seguir para un servidor en producción, pero esa la dejaremos como segunda parte de este blog.
 Pero nos dará una idea de que es lo principal que se necesita para montar servidor web casero. 
 
Abrir una terminal/consola.


Instalamos el servidor Web Apache:
 sudo apt-get install apache2 -y
 
Lo podemos comprobar abriendo un navegador en la dirección:
 

 Instalamos el PHP 5 cómo módulo:

sudo apt-get install php5 libapache2-mod-php5 -y
 
Reiniciamos el servidor web:
sudo /etc/init.d/apache2 restart
 
El directorio www por default es:
/var/www
 
Si no tenemos permiso para manipular su contenido, se lo damos con lo siguiente. Cambiamos el propietario del directorio y el grupo que debe usarlo. Reemplazar USUARIO con el nombre de usuario que estén utilizando:
sudo chown -R USUARIO:www-data /var/www
 Se le dan permisos de lectura y ejecución para todos y de escritura sólo al propietario:
sudo chmod -R 755 /var/www
 Ahora creamos el info.php de rigor para comprobar el funcionamiento de PHP:
sudo gedit /var/www/info.php
 Pegar lo siguiente dentro, luego salvar y cerrar:
<?php phpinfo(); ?>
 Comprobar entrando a la dirección: 
 
Tendría que aparecer toda la información de configuración del PHP y sus módulos instalados. 
 
 
Seguimos con la instalación del servidor y el cliente de MySQL

sudo apt-get install mysql-server mysql-client -y

Pedirá clave para el usuario root y luego la confirmación de la misma. Ahora podemos instalar todos estos módulos, mejor que sobre y no que falte.
sudo apt-get install php5-mysql php5-curl php5-gd php5-idn php-pear php5-imagick php5-imap php5-mcrypt php5-memcache php5-ming php5-ps php5-pspell php5-recode php5-snmp php5-sqlite php5-tidy php5-xmlrpc php5-xsl -y.

Entre ellos va el soporte para MySQL, cURL, etc. Ahora otro reinicio del servidor web:sudo /etc/init.d/apache2 restart

  
Instalamos la interfaz web para manejar el MySQL y sus bases de datos, phpMyAdmin:
sudo apt-get install phpmyadmin -y 
Preguntará para que servidor web configurar, elegir apache2 y continuar. Luego pedirá configurar la base de datos con dbconfig-common elegir que No.
Comprobar si funciona entrando a:
http://127.0.0.1/phpmyadmin 
Si no funciona, ejecutar:
sudo gedit /etc/apache2/httpd.conf 

Pegar lo siguiente dentro, luego salvar y cerrar:

Include /etc/phpmyadmin/apache.conf 

Reiniciar el servidor web nuevamente:

sudo /etc/init.d/apache2 restart 

Y con eso ya debería estar todo funcionando.
Archivos y rutas importantes:
* acá están todos los virtual hosts habilitados

/etc/apache2/sites-enabled

* el virtual host por default, de este se pueden hacer copias

/etc/apache2/sites-available/default

* el archivo de configuración de PHP

/etc/php5/apache2/php.ini

* el archivo de configuración global de MySQL

/etc/mysql/my.cnf

sábado, 3 de noviembre de 2012

DJANGO: INSTALACIÓN Y APLICACIÓN (Parte V)

DJANGO: INSTALACIÓN Y APLICACIÓN (Parte IV)

DJANGO: INSTALACIÓN Y APLICACIÓN (Parte III)


Una vez que ya tenemos instalado Django, creado nuestro primer proyecto y haber revisado como funciona, necesitamos definir el modelo de datos para nuestra aplicación.

EL MODELO

Un modelo es la representación de los datos de nuestra aplicación. Contiene los campos básicos y el comportamiento de los datos que serán almacenados. Por lo general, cada modelo se convierte en una tabla de la base de datos.

LO FUNDAMENTAL

  • Cada modelo es una subclase de django.db.models.Model.
  • Cada atributo de un modelo representa a un campo de una tabla.
  • Django automáticamente nos da acceso a la base de datos.

REFERENCIA DE LOS CAMPOS

La referencia de la versión actual esta detallada por completo en la documentación del framework, con este recurso podemos elaborar todas las referencias necesarias para el proyecto, sin embargo leerlo por completo puede resultar al principio un poco tedioso.
Para ello siempre es muy útil un cheatsheet o chuleta para poder visualizarlos juntos.
Chuleta - Modelos en Django
Chuleta - Modelos en Django

EJEMPLO DE MODELO EN NUESTRO PROYECTO

Vamos con el ejemplo del capítulo para poder entender mejor como va esto del modelo.

NOTA

Para poder continuar con este ejemplo, tienen que seguir el curso desde el primer capítulo y evitar solamente copiar y pegar, escribanlo que es mejor en todo sentido.
Capturar a Evernote
Nuestro archivo: models.py de la semana pasada quedó así:
from django.db import models

class Bebida(models.Model):
 nombre = models.CharField(max_length=50)
 ingredientes = models.TextField()
 preparacion = models.TextField()

 def __unicode__(self):
  return self.nombre
Este modelo solo fue un ejemplo para saber cómo funcionaba, ahora redactaré algunas líneas que nos ayudarán a tener un modelo más completo:
#encoding:utf-8
from django.db import models
from django.contrib.auth.models import User

class Bebida(models.Model):
  nombre = models.CharField(max_length=50)
  ingredientes = models.TextField()
  preparacion = models.TextField()

  def __unicode__(self):
      return self.nombre

class Receta(models.Model):
  titulo = models.CharField(max_length=100, unique=True)
  ingredientes = models.TextField(help_text='Redacta los ingredientes')
  prepacion = models.TextField(verbose_name='Preparación')
  imagen = models.ImageField(upload_to='recetas', verbose_name='Imágen')
  tiempo_registro = models.DateTimeField(auto_now=True)
  usuario = models.ForeignKey(User)
 
  def __unicode__(self):
      return self.titulo
Son clases en Python (respetar la indentación), les explicaré de que trata todo esto:
#encoding:utf-8 <- Esta línea permite usar tíldes y caracteres especiales 
from django.db import models <- Clase con la descripción de modelos
from django.contrib.auth.models import User <- Llama al modelo usuario
La clase Bebida de la semana anterior sólo era un ejemplo, no le daremos importancia de ahora en adelante, pasemos con la clase Receta (y sus respectivos comentarios previos a cada línea).
#Dato cadena, longitud máxima 100 y único
titulo = models.CharField(max_length=100, unique=True)

#Dato texto, con texto de ayuda
ingredientes = models.TextField(help_text='Redacta los ingredientes')

#Dato texto, con nombre: Preparación
prepacion = models.TextField(verbose_name='Preparación')

#Dato imagen, se almacenarán en la carpeta recetas, titulo: Imágen
imagen = models.ImageField(upload_to='recetas', verbose_name='Imágen')

#Dato Fecha y Hora, almacena la fecha actual
tiempo_registro = models.DateTimeField(auto_now=True)

#Enlace al modelo Usuario que Django ya tiene construido
usuario = models.ForeignKey(User)
La clase Receta (modelo) tiene un atributo imagen, el cuál está direccionando las cargas que haga el usuario a la carpeta ‘recetas’ (carpeta que estará dentro de otra llamada: ‘carga’), para que esto funcione debemos modificar nuestro archivo settings.py, exactamente debemos buscar la línea: MEDIA_ROOT (debe ser la número 56 aproximadamente), y dejarla así:
MEDIA_ROOT = os.path.join(RUTA_PROYECTO,'carga')
Luego de haber puesto esta línea, debemos crear una carpeta que se llame ‘carga’ dentro de la carpeta del proyecto. Debemos tener un árbol de ficheros de este tipo:
Mapa de ficheros del proyecto recetario
Mapa de ficheros del proyecto recetario
Dentro de esta carpeta ‘carga’ aparecerá una carpeta ‘recetas’ al momento de guardar un registro. Pero antes de ello debemos buscar el archivo admin.py y dejarlo asi:
from principal.models import Bebida, Receta
from django.contrib import admin

admin.site.register(Bebida)
admin.site.register(Receta)
Esto nos permitirá agregar el modelo Receta dentro de la interfaz administrativa.
Por último debemos habilitar las URL para poder visualizar las imágenes, para ello debemos dejar el archivo urls.py asi:
from django.conf.urls import patterns, include, url
from django.contrib import admin
from django.conf import settings

admin.autodiscover()

urlpatterns = patterns('',
    url(r'^$','principal.views.lista_bebidas'),
    url(r'^admin/doc/', include('django.contrib.admindocs.urls')),
    url(r'^admin/', include(admin.site.urls)),
    url(r'^media/(?P.*)$','django.views.static.serve',
  {'document_root':settings.MEDIA_ROOT,}
 ),
)
Esto nos permitirá acceder a las imágenes que subamos desde http://127.0.0.1:8000/media/recetas/nombre-imagen.jpg (o cualquier otra imagen).

PONIENDO A CORRER TODO

Para hacer funcionar todo, debemos sincronizar la base de datos nuevamente (esto se debe hacer cada vez que se modifique el modelo).

NOTA

Toda ejecución de comando se debe hacer desde una terminal o ventana de comando y dentro de la carpeta del proyecto (donde se encuentra el archivo manage.py)
Capturar a Evernote
python manage.py syncdb
Y esto nos debe mostrar un resultado así (prestar atención a la segunda línea):
python manage.py syncdb
python manage.py syncdb
En caso de que queramos modificar un modelo ya existente podemos también reiniciar todos los modelos de la aplicación principal así:
python manage.py reset principal
Sin embargo si ya se tienen datos almacenados estos se perderán al momento de reiniciarlos, para evitar eso podemos usar aplicaciones como South, que nos permitirán trabajar con los datos de manera más profesional. Aquí un video de ejemplo:

PROBANDO EL EJEMPLO

Ya tenemos todo listo, el modelo nuevo sincronizado, las configuraciones listas y la interfaz administrativa. Corremos el proyecto:
python manage.py runserver
Entramos a http://127.0.0.1:8000/admin y debemos observar el nuevo modelo: Recetas, listo para ser usado. Para ver las imágenes que se van cargando podemos ir a http://127.0.0.1:8000/media/recetas/nombre-imagen.jpg y si son proactivos, pueden modificar la plantilla de la semana pasada para poder ver el nuevo modelo de Recetas y sus imágenes, o pueden crear nuevos modelos para ver como pueden interactuar entre sí.
No se olviden que pueden revisar el repositorio del proyecto en github si desean comprobar como deben quedar los archivos (en orden y en contenido).
La próxima semana sabremos que hacer con estos modelos y como interactuar con sus datos, lo haremos a través de la Shell de Django.
Que tengan un buen inicio de semana con Django, no se olviden comentar, twittear y hacer todas sus consultas, para poder ayudarlos.

DJANGO: INSTALACIÓN Y APLICACIÓN (Parte II)


ENTENDIENDO COMO TRABAJA DJANGO

La semana pasada vimos lo fácil que fue crear un proyecto y ejecutarlo en unos cuantos pasos, sin embargo esa simplicidad debe ir acompañada de una fuerte lógica para poder aplicar Django a proyectos reales, es por eso que esta semana nos dedicaremos a entender como es que Django hace toda esa magia.

NOTA

Para tener una estupenda experiencia con Django, el orden de los archivos y directorios deben respetarse, caso contrario el caos llegará rápidamente a nuestro proyecto y fracasará al momento de hacerlo crecer con mas personas o requerimientos.
Capturar a Evernote
Antes de iniciar con la explicación de como funciona Django, dale un vistazo a este vídeo:

Ahora que ya entiendes el contexto, empezamos!

MTV Y DJANGO

Se podría clasificar a Django como parte de la tercera generación del desarrollo web:
Generaciones del desarrollo web
Generaciones del desarrollo web
Sin embargo más alla de las clasificaciones que podrían existir, está el entender como funciona realmente, al entenderlo se puede llegar a dominarlo.
Al principio del curso de Django, les dije que era un framework MTV (una modificación de MVC, nada que ver con música), esto se debe a que los desarrolladores no tuvieron la intención de seguir algún patron de desarrollo, sino hacer el framework lo más funcional posible.
Para empezar a entender MTV debemos fijarnos en la analogía con MVC.
  • El modelo en Django sigue siendo modelo
  • La vista en Django se llama Plantilla (Template)
  • El controlador en Django se llama Vista
Una imagen nos hará entender mejor esta relación:
Funcionamiento del MTV de Django
Funcionamiento del MTV de Django
Veamos que hace cada uno de ellos con un poco más de detalle y algunos conceptos adicionales.

EL MODELO

El modelo define los datos almacenados, se encuentra en forma de clases de Python, cada tipo de dato que debe ser almacenado se encuentra en una variable con ciertos parámetros, posee métodos también. Todo esto permite indicar y controlar el comportamiento de los datos.

LA VISTA

La vista se presenta en forma de funciones en Python, su propósito es determinar que datos serán visualizados, entre otras cosas más que iremos viendo conforme avanzamos con el curso. El ORM de Django permite escribir código Python en lugar de SQL para hacer las consultas que necesita la vista. La vista también se encarga de tareas conocidas como el envío de correo electrónico, la autenticación con servicios externos y la validación de datos a través de formularios. Lo mas importante a entender con respecto a la vista es que no tiene nada que ver con el estilo de presentación de los datos, sólo se encarga de los datos, la presentación es tarea de la plantilla.

LA PLANTILLA

La plantilla es básicamente una página HTML con algunas etiquetas extras propias de Django, en si no solamente crea contenido en HTML (también XML, CSS, Javascript, CSV, etc).
Por ahora nos enfocaremos a lo básico el HTML. La plantilla recibe los datos de la vista y luego los organiza para la presentación al navegador web. Las etiquetas que Django usa para las plantillas permiten que sea flexible para los diseñadores del frontend, incluso tiene estructuras de datos como if, por por si es necesaria una presentación lógica de los datos, estas estructuras son límitadas para evitar un desorden poniendo cualquier tipo de código Python.
Esto permite que la lógica del sistema siga permaneciendo en la vista.

LA CONFIGURACIÓN DE LAS RUTAS

Django posee un mapeo de URLs que permite controlar el despliegue de las vistas, esta configuración es conocida como URLConf. El trabajo del URLConf es leer la URL que el usuario solicitó, encontrar la vista apropiada para la solicitud y pasar cualquier variable que la vista necesite para completar su trabajo. El URLConf esta construido con expresiones regulares enPython y sigue la filosofia de Python: Explicito es mejor que implícito. Este URLConf permite que las rutas que maneje Django seán agradables y entendibles para el usuario.
Si consideramos al URLConf en el esquema anterior tendríamos este resultado más completo.
Funcionamiento del MTV de Django y su URLConf
Funcionamiento del MTV de Django y su URLConf

LOS ARCHIVOS PREDETERMINADOS

Otra parte importante es entender el propósito de los archivos que se crean de manera predeterminada, estos son:

ARCHIVOS DEL PROYECTO

  • __init__.py: Este es un archivo vacío que le dice a Python que debe considerar este directorio como un paquete de Python. Si se desea saber más, se puede consultar la documentación sobre los paquetes.
  • manage.py: Este archivo contiene una porción de código que permite interactuar con el proyecto de Django de muchas formas. Si se desea mayor detalle se encuentra ladocumentación oficial con respecto a manage.py.
  • settings.py: Este archivo contiene todas las configuraciones para el proyecto, la documentación al respecto puede darnos mas detalles de la configuración de un proyecto en Django.
  • urls.py: Contiene las rutas que están disponibles en el proyecto, manejado por URLConf, los detalles completos como siempre en la documentación oficial nos da mas detalles sobre las urls y Django.

ARCHIVOS DE LA APLICACIÓN

  • __init__.py: La misma descripción anterior (líneas arriba).
  • models.py: En este archivo se declaran las clases del modelo.
  • views.py: En este archivo se declaran las funciones de la vista.
  • test.py: En este archivo se declaran las pruebas necesarias para la aplicación, para mayor detalle sobre las pruebas y Django se puede consultar la documentación del proyecto.
Una vez que tenemos claro el funcionamiento básico de Django, desarrollemos un ejemplo dentro del proyecto que iniciamos la semana pasada, para experimentar por nuestra cuenta.

MODELO, VISTA Y PLANTILLA EN 15 MINUTOS

Antes de continuar, deben entender que esto solamente es un pequeño ejemplo, el modelo, vista y plantillas serán desarrolladas a detalle en las próximas semanas. Si existen dudas del porque de las instrucciones, estas serán resueltas a detalle en los siguientes capítulos. Si eres muy impaciente siempre tienes a disposición la documentación oficial del proyecto.
Nuestro proyecto debe tener una estructura similar a esta:
Árbol de ficheros de un proyecto en Django
Árbol de ficheros de un proyecto en Django
Tendremos que manejar para este proyecto 6 archivos:
  • models.py (ya existe dentro de la carpeta principal).
  • views.py (ya existe dentro de la carpeta principal).
  • admin.py (aún no existe, pero estará dentro de la carpeta principal).
  • urls.py (ya existe dentro de la carpeta recetario).
  • settings.py (ya existe dentro de la carpeta recetario).
  • lista_bebidas.html (aún no existe, estará dentro de una carpeta en la carpeta recetario).

MODELS.PY

Al principio models.py luce asi:
models.py predeterminado
models.py predeterminado
Usamos nuestro editor de texto favorito para editar models.py y redactamos lo siguiente:
from django.db import models

class Bebida(models.Model):
 nombre = models.CharField(max_length=50)
 ingredientes = models.TextField()
 preparacion = models.TextField()

 def __unicode__(self):
  return self.nombre

VIEWS.PY

views.py luce así al principio:
views.py predeterminado
views.py predeterminado
Igualmente con nuestro editor favorito abrimos views.py y lo dejamos de la siguiente forma:
from principal.models import Bebida
from django.shortcuts import render_to_response

def lista_bebidas(request):
 bebidas = Bebida.objects.all()
 return render_to_response('lista_bebidas.html',{'lista':bebidas})

ADMIN.PY

Este archivo no existe, así que lo creamos manualmente dentro de nuestro directorio de la aplicación, en este caso dentro del directorio principal. Lo debemos dejar de esta manera:
from principal.models import Bebida
from django.contrib import admin

admin.site.register(Bebida)

URLS.PY

Este archivo ya existe, se encuentra dentro del directorio recetario, así que lo único que debemos hacer es modificarlo para dejarlo de la siguiente manera:
from django.conf.urls import patterns, include, url
from django.contrib import admin

admin.autodiscover()

urlpatterns = patterns('',
    url(r'^$','principal.views.lista_bebidas'),
    url(r'^admin/doc/', include('django.contrib.admindocs.urls')),
    url(r'^admin/', include(admin.site.urls)),
)

SETTINGS.PY

Este archivo lo modificamos la semana pasada, se encuentra dentro de recetario. Debemos buscar la directiva TEMPLATE_DIRS (Debe encontrarse en la línea 113 aproximadamente). Debemos dejar esta sección de esta forma:
TEMPLATE_DIRS = (
    os.path.join(RUTA_PROYECTO,'plantillas'),
)
En esta sección le estamos diciendo que debe buscar las plantillas dentro de la carpeta del proyecto, en una carpeta llamada plantillas, como esta carpeta aún no existe debemos crearla manualmente dentro de recetario.

LISTA_BEBIDAS.HTML

Este archivo no existe, lo crearemos manualmente dentro de la carpeta plantillas (si, esa que acabas de crear dentro de recetario).
Debes finalizar con una estructura similar a esta:
Árbol de ficheros del proyecto recetario
Árbol de ficheros del proyecto recetario
Una vez creado le ponemos la etiquetación HTML que nos permita visualizar la lista de bebidas. Podría quedarse de esta manera:
<!DOCTYPE html>
<html lang='es'>
  <head>
 <title>Lista de bebidas de ejemplo</title>
 <meta charset='utf-8'>
  </head>
  <body>
    <h1>Recetario de Bebidas</h1>
 {% for elemento in lista %}
 <ul>
   <li><strong>{{elemento.nombre}}</strong></li>
   <li>{{elemento.ingredientes}}</li>
   <li>{{elemento.preparacion}}</li>
 </ul>
 {% endfor %}
  </body>
</html>

NOTA: PYTHON ES SENSIBLE A LAS MAYÚSCULAS Y MINÚSCULAS

Tener precaución al momento de digitar el código en Python, las mayúsculas y minúsculas importan y mucho.
Capturar a Evernote

PONER EN FUNCIONAMIENTO TODO

Listo, tenemos todo listo para ver funcionando nuestro ejemplo, para ello debemos de sincronizar nuevamente nuestra base de datos, para ello, nos ubicamos en la carpeta principal del proyecto (aquella donde se encuentra el archivo manage.py). Una vez en la carpeta principal, desde una terminal digitamos:
python manage.py syncdb
Esto nos dará el siguiente resultado: (prestar atención a la segunda línea que nos indica la creación de una nueva tabla):
Creación de tabla principal_bebidas
Creación de tabla principal_bebidas
Una vez realizado esto, lanzamos nuestro servidor de desarrollo:
python manage.py runserver
Nos ubicamos en http://127.0.0.1:8000/admin, ingresamos con nuestros datos configurados en la primera vez que sincronizamos la base de datos (si no recuerdas los datos que pusiste, puedes borrar el archivo recetario.db y volver a digitar: python manage.py syncdb para resincronizar).
Una vez dentro de la interfaz administrativa veremos: (notar que aparece una opción Bebidas).
Interfaz administrativa de Django + Bebidas
Interfaz administrativa de Django + Bebidas
Podemos seguir intuitivamente la interfaz e ingresar datos:
Interfaz inicial de bebidas
Interfaz inicial de bebidas

Formulario para ingreso de datos
Formulario para ingreso de datos

Ingreso de contenido
Ingreso de contenido

Lista de elementos ingresados
Lista de elementos ingresados
Una vez guardados podemos ir a http://127.0.0.1:8000/ y veremos lo que acabamos de ingresar. De esta manera ya tienes una interfaz rápida de ingreso y visualización de datos.
Ejemplo de plantilla con Django
Ejemplo de plantilla con Django
Hay muchos puntos que en este capítulo he tenido que tocar superficialmente, esto no debe preocuparte, porque en los siguientes capítulos desarrollaré a detalle esos puntos, deseo recordarte que el objetivo de este pequeño ejemplo, es disfrutar la experiencia de la velocidad de Django, para el desarrollo de aplicaciones.
Si desean ver los archivos oficiales del proyecto, no olviden que pueden acceder al repositorio del mismo en github. Los datos de acceso para la interfaz administrativa del ejemplo del repositorio son los siguientes:
  • usuario:sergio
  • clave:maestros
La próxima semana tendremos el capítulo dedicado a El Modelo. Muchas gracias por sus comentarios en el capítulo anterior, eso enriquece mucho más cada capítulo.