CriminalDataVE: Hackaton de Datos Abiertos (1er Lugar)

Entre lunes 28 y martes 29 de noviembre se efectuó el Hackaton de Datos Abiertos en Wayra, organizado por la gente de ChicasPoderosasVE, un excelente espacio de aprendizaje colaborativo y de compartir experiencias con otras personas que desean, cambiar el país que tenemos.

Fui con @BellaDesiree, fue una experiencia inolvidable, tanto para ella, como para mi, conocimos personas geniales y con mucho talento, nos involucramos en un proyecto el cual quedo con el nombre de @CriminalDataVE y que busca contar historias detrás de los homicidios y así generar una estadística general de todas las muertes violentas ocurridas en el país, con ello evaluar, estudiar y/o definir patrones de esos sucesos.

Logramos generar un prototipo de la aplicación (Web y un Launcher para IOS y Android), a las 4:00pm del martes 29 presentamos ante el jurado la solución al problema de la falta de data real acerca de las muertes violentas en el país, la cual encanto, al jurado y al publico presente, fuimos merecedores del 1er Lugar del Hackaton de Datos Abiertos.

Ahora, como equipo, continuamos trabajando para desarrollar la aplicación completa de esta solución, nos mantenemos en contacto y hasta buscamos financiamiento de parte de algunas personas y medios involucrados con el mundo periodístico.

photo_2016-11-30_14-10-08

 

Felicitaciones equipo y a continuar trabajando🙂

 

Happy Hacking

 

DetailView Django

Para entender un poco lo que es la Class Based View (CBV) podemos decir que:

A view is a callable which takes a request and returns a response. This can be more than just a function, and Django provides an example of some classes which can be used as views. These allow you to structure your views and reuse code by harnessing inheritance and mixins. There are also some generic views for simple tasks which we’ll get to later, but you may want to design your own structure of reusable views which suits your use case

Ahora bien, el DetailView de forma sencilla te la explico así:


from django.views.generic import DetailView
from .models import ModeloImportado
class DetailModeloimportado(DetailView):
template_name = 'detailview.html'
model = ModeloImportado
context_object_name = 'postdetail'
def get_context_data(self, **kwargs):
context = super(DetailModeloimportado, self).get_context_data(**kwargs)
context['postall'] = self.model.objects.all().order_by('-p_datecreated')
return context

 

Respetar las identaciones del código, a mi me fallan al momento de escribir este post.

Con esto simplemente en el views.py le diremos a Django que nos muestre de manera detallada cada uno de los objectos del modelo, ahora haremos unos cambios en el urls.py


url(r'^post/(?P[0-9]+)/$', DetailModeloimportado.as_view(), name='postall'),

Ahora en el template simplemente debemos colocarla el para que desde el enlace podamos navegar a través de los objectos del modelo.



Y en el detailview.html simplemente llamamos de la siguiente forma:


{{ postdetail.p_title }}

Como puedes ver en el detailview.html llamamos {{ postdetail.p_title }} el postdetail lo definimos en context_object_name = ‘postdetail’ en el views.py

Crear una imagen de nuestros modelos en Django

Hace un tiempo conocí la posibilidad de hacer una imagen con tus modelos de tus apps Django, el proceso es bastante simple y sirve para que veas como estarían quedando relacionados tus apps. Comencemos entonces.

Lo primero es que debes tener instalado
pip install pygraphviz
Una vez instalado debes instalar django_extensions y colocarlo en settings.py, esto puedes hacerlo con el comando
pip install django_extensions

Ahora, simplemente ejecutas
./manage.py graph_models -a -g -o mis_modelos.png

Puedes ejecutar el comando especificando cuales apps mostrar en la imagen con el siguiente comando
./manage.py graph_models app1 app2 app3 -o mis_modelos.png
models