Django request.method ='GET'无效

时间:2015-03-25 05:23:19

标签: python html django postgresql psycopg2

我试图在我的应用上加载数据库表数据,以便对其进行更新,到目前为止,我发现这是由request.method = 'GET'不知道是否已完成总是这样,但肯定是实现这一目标的方法之一。

但是,我的应用程序充满了POST个请求,要在db表上创建新文档,我只需要通过指定其名称来检索其中一个。使用'GET'方法。但它不起作用,似乎它没有评估表达,我真的不知道为什么。

这是我的models.py

class Proyecto(models.Model):
    id_proyecto = models.IntegerField(primary_key=True) #integer NOT NULL, CLAVE PRIMARIA
    nombre_proyecto = models.TextField(null=True) #text,
    fecha_creacion = models.DateField(null=True) #date,
    existente = models.BooleanField()

    def __unicode__(self):
        return u'%s | %s ' % (self.id_proyecto, self.nombre_proyecto)

    class Meta:
        unique_together = [("id_proyecto","nombre_proyecto")]
        db_table = 'proyecto'

我会使用existente BooleanField作为我的模板的复选标记,如果此existente处于有效状态,则会通过它nombre_proyecto字段执行查询(项目名称)并带上指定的文件。

我的forms.py

class ProyectoForm(forms.Form):
    nombre_proyecto = forms.CharField(widget=forms.TextInput())
    existente = forms.BooleanField(required=False)

    def clean(self):
        return self.cleaned_data

我的views.py方法所在的位置:

def proyecto_view(request):
    alerta=""
    if request.method == "POST":
        form = ProyectoForm(request.POST)
        if form.is_valid():
            name =form.cleaned_data['nombre_proyecto'] #hay que verificar si el proyecto ya existe
        if existente is not None and existente != '':
            projects = Proyecto.objects.filter(nombre_proyecto=name)
            ctx = {"projects" : projects}
            return render_to_response('scppp/proyecto.html', ctx, context_instance=RequestContext(request))
        if Proyecto.objects.filter(nombre_proyecto=name).exists():
            alerta="ya existe el proyecto"
            formProy = 1
            ctx ={'alerta':alerta, 'formProy':formProy}
            return render_to_response('scppp/inicial.html', ctx, context_instance=RequestContext(request))
        else:
            if not name:    
                id_proyecto=1
            else:
                id_proyecto=Proyecto.objects.all().aggregate(Max('id_proyecto'))['id_proyecto__max']+1
                nombre_proyecto = name
    else:
        alerta = "data erronea"
        formProy = 1
        ctx = {'alerta':alerta, 'formProy':formProy}
        return render_to_response('scppp/inicial.html', ctx, context_instance=RequestContext(request))

    sombra = "style=\"color: #a2a2a2;\""
    num = ""
    slash = ""
    quotes = ""
    arenas = ""
    fluidos = ""
    onclick = ""
    sombra2 = sombra
    graf = ""
    formProy = 0
    ctx = {'id_proyecto':id_proyecto,'nombre_proyecto':nombre_proyecto, 'sombra':sombra, 'sombra2':sombra2, 'graf':graf, 'num':num, 'slash':slash, 'quotes':quotes, 'arenas':arenas, 'fluidos':fluidos, 'onclick':onclick, 'alerta':alerta, 'formProy':formProy}
    return render_to_response('scppp/proyecto.html', ctx, context_instance=RequestContext(request))
else:
    form = ProyectoForm()
    formProy = 1
    ctx = {'form': form, 'formProy': formProy}
    return render_to_response('scppp/inicial.html', ctx, context_instance=RequestContext(request))

此处if existente is not None and existente != '':条件值应评估inicial.html上的existente复选标记是否有效,如果是,则渲染proyecto.html模板。

带有复选标记的inicial.html有趣代码:

<tr><td>
    <span class="Sub-Titulo-Aplicacion">Tipo de Proyecto: </span>
    <input class="check-style" type="checkbox" name="curva" value="checkbox" >Petroleo</input>
    </td></tr>
    <tr><td>
    <input class="check-style" type="checkbox" name="curva" value="checkbox" >Gas</input>
    </td></tr>
    <tr><td>
    <span class="Sub-Titulo-Aplicacion">Proyecto: </span>
    <input class="check-style" type="checkbox" name="tipo" value="checkbox" >Nuevo</input>
    </td></tr>
    <tr><td>
    <input class="check-style" type="checkbox" name="existente" value="existente" >Existente</input>
 </td></tr>

如果此复选框处于有效状态,请渲染proyecto.html

{% for project in projects %}
            <a  class="Contenedor-Texto-Menu"><span class="Text-menu" > Datos</span></a>
             <a href="/pozos{{num}}/{{id_proyecto}}/{{nombre_proyecto}}" class="Contenedor-Texto-sub-Menu"><span class="Text-menu" > Yacimiento y Pozo</span></a>
             <a {% autoescape off %}{{arenas}}{{slash}}{{id_proyecto}}{{slash}}{{nombre_proyecto}}{{quotes}}{% endautoescape %} class="Contenedor-Texto-sub-Menu"><span class="Text-menu" {% autoescape off %}{{sombra}}{% endautoescape %}> Arena </span></a><tr>
             <a {% autoescape off %}{{fluidos}}{{slash}}{{id_proyecto}}{{slash}}{{nombre_proyecto}}{{quotes}}{% endautoescape %} class="Contenedor-Texto-sub-Menu"><span class="Text-menu" {% autoescape off %}{{sombra}}{% endautoescape %}> Fluido </span></a><tr>
             <div style="overflow:hidden; width:0px; height:0px;">
            <form id="submitArch" action="/archivo/{{id_proyecto}}/{{nombre_proyecto}}/" method="POST" enctype="multipart/form-data">
            {% csrf_token %}
            <input id="cargarArch" type="file" class="Contenedor-Texto-sub-Menu" name="archivo" style="display:none;" onchange="submitArch()">
            </form>
            </div>
            <a class="Contenedor-Texto-sub-Menu" {% autoescape off %}{{onclick}}{% endautoescape %}><span class="Text-menu" {% autoescape off %}{{sombra}}{% endautoescape %}> Cargar un archivo </span></a><tr>
             <!--<a href="/graficos/{{id_proyecto}}/{{nombre_proyecto}}" class="Contenedor-Texto-Menu">-->
            <a {% autoescape off %}{{graf}}{% endautoescape %} class="Contenedor-Texto-Menu" {% autoescape off %}{{sombra2}}{% endautoescape %}><span class="Text-menu" > Procesamiento </span></a><tr>
            <a  class="Contenedor-Texto-Menu" {% autoescape off %}{{sombra2}}{% endautoescape %}><span class="Text-menu" > Reporte </span></a><tr>
{% endfor %}

这是existente BooleanField的所有逻辑,对不起,如果这听起来很无趣,但这是一个已经启动的项目,有时会让人感到困惑。

如果你知道为什么这个没有评估有条件的PLZ让我知道,我就无法弄清楚。

非常感谢提前!

PS =我使用Django==1.6.1,Python 3.3.1和PostgreSQL v9.0。

1 个答案:

答案 0 :(得分:1)

无需使用filter.exists。只需要

if Proyecto.objects.filter(nombre_proyecto=name):

如果查询与任何文档都不匹配,它将返回[]。因此,ID不会进入if条件。因为emptylist emptystring引用{{1}在python中。

  

如果你想做的就是确定是否存在至少一个结果。使用exists()更有效率。

False

如果您想if Proyecto.objects.filter(nombre_proyecto=name).exists(): 。只需使用update

get

如果要更新查询集中的proyecto = Proyecto.objects.get(nombre_proyecto=name) proyecto.nombre_proyecto = "newname" proyecto.save() 个文档。

multiple

注意 如果Proyecto.objects.filter(nombre_proyecto=name).update(nombre_proyecto="newname") 提供了多个文档,请不要使用Proyecto.objects.filter(nombre_proyecto=name)。请使用get。否则会出现update错误。