Articles
Actualizar modelo Django
On febrero 18, 2021 by admin¿Cómo puedo mejorar esto? Es grande y feo. ¿Algún consejo?
Estoy recibiendo un POST de una API y quiero actualizar solo los campos que no son nulos.
titulo = request.data.get("titulo", "") image = request.data.get("image", "") price = request.data.get("price", "") wholesale_price = request.data.get("wholesale_price", "") reference = request.data.get("reference", "") ean13 = request.data.get("ean13", "") rating = request.data.get("rating", "") sales = request.data.get("sales", "") active = request.data.get("active", "") encilleria = request.data.get("encilleria", "") delivery = request.data.get("delivery", "") summary = request.data.get("summary", "") brand_id = request.data.get("brand_id", "") consejos = request.data.get("consejos", "") ingredientes = request.data.get("ingredientes", "") stock = request.data.get("stock", "") es_pack = request.data.get("es_pack", "") descontinuado = request.data.get("descontinuado", "") tags = request.data.get("tags", "") destacado_buscado = request.data.get("destacado_buscado", "") supplier_delivery = request.data.get("supplier_delivery", "") imagen_mala = request.data.get("imagen_mala", "") guia_cosmetica_attrs = request.data.get("guia_cosmetica_attrs", "") guia_cosmetica_cats = request.data.get("guia_cosmetica_cats", "") try: producto = Product.objects.get(pk=product_id) if titulo != "": producto.titulo = titulo if titulo != "": producto.slug = slugify(titulo) if image != "": producto.image = image if price != "": producto.price = price if wholesale_price != "": producto.wholesale_price = wholesale_price if reference != "": producto.reference = reference if ean13 != "": producto.ean13 = ean13 if rating != "": producto.rating = rating if sales != "": producto.sales = sales if active != "": producto.active = active if encilleria != "": producto.encilleria = encilleria if delivery != "": producto.delivery = delivery if summary != "": producto.summary = summary if brand_id != "": producto.brand_id = brand_id if consejos != "": producto.consejos = consejos if ingredientes != "": producto.ingredientes = ingredientes if stock != "": producto.stock = stock if es_pack != "": producto.es_pack = es_pack if descontinuado != "": producto.descontinuado = descontinuado if tags != "": producto.tags = tags if destacado_buscado != "": producto.destacado_buscado = destacado_buscado if supplier_delivery != "": producto.supplier_delivery = supplier_delivery if imagen_mala != "": producto.imagen_mala = imagen_mala if guia_cosmetica_attrs != "": producto.guia_cosmetica_attrs = guia_cosmetica_attrs if guia_cosmetica_cats != "": producto.guia_cosmetica_cats = guia_cosmetica_cats try: producto.save() except ValueError: return Response({"success": False, "msg": "Value Error"}) except ObjectDoesNotExist: return Response({"success": False, "msg": "Product does not exist"})
Comentarios
- Esta pregunta está incompleta. Para ayudar a los revisores a brindarle mejores respuestas, agregue suficiente contexto a su pregunta. Cuanto más nos cuente sobre lo que hace su código y cuál es el propósito de hacerlo, más fácil será para los revisores ayudarlo. Las preguntas deben incluir una descripción de lo que hace el código
Respuesta
Puede utilizar .update()
queryset y descomprimir el request.data
diccionario:
product.objects.filter(pk=product_id).update(**request.data)
O puede recorrer request.data
elementos y use la setattr()
función incorporada :
producto = Product.objects.get(pk=product_id) for attr, value in request.data.items(): if value: # check if value is "truthy" - you may not need this check, please test setattr(producto, attr, value) producto.save()
Tenga en cuenta que puede y debe manejar la parte «slugify» de manera diferente, por ejemplo, anulando el método «s save()
del modelo y creando un slug si un titulo
se proporciona – ejemplo aquí .
Comentarios
- ¡Vaya, eso ' es increíble! Es ' seguro contra la inyección de SQL, ¿verdad?
- @MarcosAguayo absolutamente, pasa por el ORM de Django y yo s seguro para inyecciones. Gracias.
Deja una respuesta