1

我还没有找到足够好的答案,所以我在这里问。我有股息和股票模型。

class Dividend(models.Model):
    attributes...
    stock = models.ForeignKey(Stock)

我需要创建 Queryset 的副本,因为我想将带有一些额外值的红利传递给我的模板,并且我不希望将这些额外值插入到数据库中。

dividend_set = stock.dividend_set.all().order_by('date')
dividend_set.create(...)

我怎样才能做到这一点?上面的代码将在我的 stock.dividend_set 中创建数据。我是否必须使用 deepcopy 或将查询集转换为列表?还是有更优雅的方式?

4

1 回答 1

5

一种简单的方法是将查询集转换为列表。该列表将包含您的模型的实例。您可以对这些实例执行任何您喜欢的操作,除非您调用save或写入数据库的其他方法之一,否则不会将任何内容保存到数据库中。

dividend_set = stock.dividend_set.all().order_by('date')
dividends = list(dividend_set)
for dividend in dividends:
    dividend.extra_value1 = 'foo'
    dividend.extra_value2 = 'bar'
# now pass the dividends list to your template as part of your context rather than the qs
于 2013-09-11T21:37:21.390 回答