Mysql
 sql >> Base de Dados >  >> RDS >> Mysql

Entrada de usuário muito simples no django


Se entendi corretamente, você deseja obter alguma entrada do usuário, consultar o banco de dados e mostrar os resultados do usuário com base na entrada. Para isso você pode criar um formulário django simples que receberá a entrada. Então você pode passar o parâmetro para uma visão em GET solicitar e consultar o banco de dados para a palavra-chave.

EDITAR :Eu editei o código. Deve funcionar agora.

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>

Certifique-se também de colocar seus modelos em uma pasta separada chamada templates e adicione isso em seu settings.py :
TEMPLATE_DIRS = (
    os.path.join(os.path.dirname(__file__), '../templates').replace('\\','/'),
)