Mysql
 sql >> Database >  >> RDS >> Mysql

Input utente molto semplice in django

Se ho capito bene, vuoi prendere alcuni input dall'utente, interrogare il database e mostrare i risultati dell'utente in base all'input. Per questo puoi creare un semplice modulo django che prenderà l'input. Quindi puoi passare il parametro a una vista in GET richiedere e interrogare il database per la parola chiave.

MODIFICA :Ho modificato il codice. Dovrebbe funzionare ora.

views.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)
)

form.html

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

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

Assicurati inoltre di posizionare i tuoi modelli in una cartella separata denominata templates e aggiungilo nel tuo settings.py :

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