0

我想在我的 html 页面中显示更多查询,但它只显示一个对象。我不知道如何添加更多

这是在 mysql、html、django1.11 和 python 2.7.15 中

视图.py

   def administrador(request):
    alumno = Alumnos.objects.get(pk=1)
    context = { 'alumno': alumno }
    mapa = mapas.objects.get(pk=4)
    context2 = { 'mapa' : mapa}
    competencias = Competencias.objects.get(pk=1)
    context3 = { 'competencias' : competencias}
    return render(request, 'competencias_app/competencias.html',context)
<form action="/competencia" method="POST">
          {% csrf_token %}

            <div class="container-alumnos">
                <div>
                <select id="carrera" name="Carrera">
                    <option value="1">TICS</option>
                    <option value="2">Carrera</option>
                    <option value="3">Carrera</option>
                    <option value="4">Carrera</option>
                    <option value="5">Carrera</option>
                </select>  
                </div>

                <div>
                    <select id="Alumno" name="Nombre">
                        <option value="{{alumno.idAlumnos}}">{{alumno.nombre}}</option>
                    </select> 
                </div>
                <form action="">
                    <label for="ID">ID</label>
                    <input type="input" name="id" disabled value="{{alumno.idAlumnos}}"><br>
                    <label for="apellidos">Apellidos</label>
                    <input type="input" name="apellidos" disabled value="{{alumno.apellidos}}"><br>
                    <label for="Correo">Correo</label>
                    <input type="input" name="Correo" disabled value="{{alumno.correo}}"><br>
                </form>

            </div>

            <select id="opciones" name="Semana">
                    <option value="1">Semana 1</option>
                    <option value="2">Semana 2</option>
                    <option value="3">Semana 3</option>
                    <option value="4">Semana 4</option>
                    <option value="5">Semana 5</option>
                </select>
            <div class="container-listas">

                <select name="OS" size=9>
                    <option selected value="0"> Elige una opción </option>
                        <optgroup label="{{mapa.nombre}}"> 
                        <option value="1">{{competencias.nombre}}</option> 
                        <option value="2">Nombre Competencia</option> 
                        <option value="3">Nombre Competencia</option> 
                    </optgroup> 
                    <optgroup label="Mapa - Nombre"> 
                        <option value="10">Nombre Competencia</option> 
                        <option value="11">Nombre Competencia</option> 
                        <option value="12">Nombre Competencia</option> 
                    </optgroup> 
                </select>

我需要添加对象映射和能力。我没有问题的对象校友

4

2 回答 2

2

.get()返回单个对象。如果你想要所有对象尝试.all()

alumno = Alumnos.objects.all()
competencias = Competencias.objects.all()

.all()返回查询集。在 html 中尝试这样

<select id="Alumno" name="Nombre">
{% for alum in alumno %}
     <option value="{{alum.idAlumnos}}">{{alum.nombre}}</option>
{% endfor %}
</select> 
于 2019-07-01T03:41:54.853 回答
1

用户filter而不是get. 因为,get返回单个对象,但filter返回所有匹配的对象。

def administrador(request):
    alumno = Alumnos.objects.filter(pk=1)
    mapa = mapas.objects.filter(pk=4)
    competencias = Competencias.objects.filter(pk=1)
    context = {
        'alumno': alumno,
        'mapa': mapa,
        'competencias': competencias
    }
    return render(request, 'competencias_app/competencias.html', context)

在你的template

对于Alumnao,

<select id="alumno" name="alumno">
{% for item in alumno %}
     <option value="{{item.id}}">{{item.your_desired_field}}</option>
{% endfor %}
</select> 

对于mapa,

<select id="mapa" name="mapa">
{% for item in mapa %}
     <option value="{{item.id}}">{{item.your_desired_field}}</option>
{% endfor %}
</select> 

对于competencias,

<select id="competencias" name="competencias">
{% for item in competencias %}
     <option value="{{item.id}}">{{item.your_desired_field}}</option>
{% endfor %}
</select> 
于 2019-07-01T05:25:45.967 回答