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

Meget simpel brugerinput i django

Hvis jeg forstår det rigtigt, vil du tage nogle input fra brugeren, forespørge i databasen og vise brugerresultaterne baseret på inputtet. Til dette kan du oprette en simpel django-formular, der tager inputtet. Derefter kan du videregive parameteren til en visning i GET anmod om og forespørg databasen efter søgeordet.

REDIGER :Jeg har redigeret koden. Det burde virke nu.

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>

Sørg også for, at du placerer dine skabeloner i en separat mappe ved navn templates og tilføj dette i din settings.py :

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


  1. korrekt dvale-annotering for byte[]

  2. Hvordan slår jeg Oracle-adgangskodeudløb fra?

  3. BLOB vs. VARCHAR til lagring af arrays i en MySQL-tabel

  4. VarBinary vs Image SQL Server-datatype til lagring af binære data?