sql >> Base de Datos >  >> RDS >> Mysql

Entrada de usuario muy simple en django

Si lo entiendo correctamente, desea recibir información del usuario, consultar la base de datos y mostrar los resultados del usuario en función de la entrada. Para esto, puede crear un formulario Django simple que tomará la entrada. Luego puede pasar el parámetro a una vista en GET solicitar y consultar la base de datos para la palabra clave.

EDITAR :He editado el código. Debería funcionar ahora.

vistas.py

from django.shortcuts import render
from django.shortcuts import HttpResponse
from .models import Person
from django.core.exceptions import *

def index(request):
    return render(request, 'form.html')

def search(request):
    if request.method == 'POST':
        search_id = request.POST.get('textfield', None)
        try:
            user = Person.objects.get(name = search_id)
            #do something with user
            html = ("<H1>%s</H1>", user)
            return HttpResponse(html)
        except Person.DoesNotExist:
            return HttpResponse("no such user")  
    else:
        return render(request, 'form.html')

urls.py

from django.conf.urls import patterns, include, url
from People.views import *

urlpatterns = patterns('',
    url(r'^search/', search),
    url(r'^index/', index)
)

formulario.html

<form method="POST" action="/search">
{% csrf_token %}
<input type="text" name="textfield">

<button type="submit">Upload text</button>
</form>

También asegúrese de colocar sus plantillas en una carpeta separada llamada templates y agrega esto en tu settings.py :

TEMPLATE_DIRS = (
    os.path.join(os.path.dirname(__file__), '../templates').replace('\\','/'),
)