Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/python/354.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python 在Django中为无序列表创建模型_Python_Django_Model - Fatal编程技术网

Python 在Django中为无序列表创建模型

Python 在Django中为无序列表创建模型,python,django,model,Python,Django,Model,在Django中创建模型字段的最佳方法是什么,以便在template中,我可以迭代其对象,如下所示: <ul> {% for item in ModelName.fieldname %} <li>{{ item }}</li> {% endfor %} </ul> {ModelName.fieldname%中的项的%s} {{item}} {%endfor%} 所以它的输出类似于,比方说: <h1>

在Django中创建模型字段的最佳方法是什么,以便在template中,我可以迭代其对象,如下所示:

<ul>
    {% for item in ModelName.fieldname %}
        <li>{{ item }}</li>
    {% endfor %}
</ul>
    {ModelName.fieldname%中的项的%s}
  • {{item}}
  • {%endfor%}
所以它的输出类似于,比方说:

<h1>Apple Products</h1>
<ul>
  <li>Ipod</li>
  <li>Apple</li>
  <li>Ipod mini</li>
  <li>Display XDR</li>
  <li>Macbook Pro</li>
</ul>
苹果产品
  • Ipod
  • 苹果
  • 迷你Ipod
  • 显示XDR
  • MacBookPro
我的想法:

  • 创建一个单独的模型,然后将其作为父模型的外键引用
  • 创建一个
    CharField
    并用逗号分隔每个列表项,然后创建一个函数;返回一个
    列表
    ,并用逗号循环分隔项的
    列表

请分享您的想法,什么是更好的方法和专业的方式来做到这一点。谢谢。

models.py中,给你

class Category(models.Model):
   name  = models.CharField(max_length=50, null=True, blank=True, unique=True)

class Product(models.Model):
  name       = models.CharField(max_length=80, null=True, blank=True, unique=True)
  category   = models.ForeignKey(Category, on_delete=models.CASCADE, null=True, blank=True)
在您的视图中.py::

def myView(request):
   my_list = []
   all_prd = Product.objects.all()
   all_cat = Category.objects.all()
   for cat in all_cat:
      temp = list(all_prd.objects.filter(category__name = cat ))
      my_list.append(temp)
   my_list = list(filter(None, my_list)
   context = [
      'my_list' : my_list,
   ]
   return(request, 'cute.html' , context)
在可爱的.html中

<ul>
   {% for item in my_list %}
       {% for prd in item %}
          {{prd.name}}
       {% endfor %}
      <br>
      <br>
   {% endfor %}
</ul>
  
    {my_list%中的项目的%s} {项目%中的prd为%1} {{prd.name} {%endfor%}

    {%endfor%}

我给了你一个提示。请随意修改。

第一个提示。肯定是第一个。这种观点非常低效,请解释一下!您正在使用许多单独的查询将整个数据库读入内存。使用
context={'my_list':Product.objects.all().order_by('category')}
可以获得几乎相同的效果,然后在视图中循环,它将一行一行地获取每一行,而不将它们存储在内存中。假设还有其他子类别。那么该怎么办?然后,您将提出另一个适合您的目的的查询。您可以迭代按某些条件排序的
Category.objects.all()
和产品,这仍然比您现在所做的更有效率。