我试图在我的应用上加载数据库表数据,以便对其进行更新,到目前为止,我发现这是由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。
答案 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
错误。