我有两个型号。其中一个是外键连接到其他。这是我的models.py:
class Baslik(models.Model):
user = models.ForeignKey(User, null=True, blank=True)
title = models.CharField(max_length=50)
slug = models.SlugField()
timestamp = models.DateTimeField(auto_now_add=True, auto_now=False)
updated = models.DateTimeField(auto_now_add=False, auto_now=True)
active = models.BooleanField(default=True)
def __unicode__(self):
return str(self.title)
def get_absolute_url(self, ):
return reverse('baslik', args=[self.slug])
class Entry(models.Model):
user = models.ForeignKey(User, null=True, blank=True)
baslik = models.ForeignKey(Baslik, null=True, blank=True)
icerik = models.TextField(max_length=50000)
timestamp = models.DateTimeField(auto_now_add=True, auto_now=False)
updated = models.DateTimeField(auto_now_add=False, auto_now=True)
def __unicode__(self):
return str(self.icerik)
我使用此功能来显示今天添加的basliks并且今天添加了一个条目,但它只是这样做,它没有根据添加的时间进行排序。 功能:
def hepsi(request):
basliklar = Baslik.objects.filter(active=True).order_by('-updated')
gunlist = []
zaman1 = date.today()
zaman2 = str(zaman1).split(" ")
zamangun = zaman2[0]
for i in basliklar:
entryler = i.entry_set.all()
sayi2 = entryler.count()
if sayi2>0:
ent1 = entryler.latest('id')
ent2 = ent1.updated
ent3 = str(ent2).split(" ")
entgun = ent3[0]
if entgun == zamangun:
gunlist.append(i)
if sayi2==0:
baslik1 = i.updated
baslik2 = str(baslik1).split(" ")
baslikgun = baslik2[0]
if baslikgun==zamangun:
gunlist.append(i)
cta = {'basliklar': basliklar, 'entryler': entryler, 'ent1': ent1, 'ent2': ent2, 'entgun': entgun, 'zamangun': zamangun, 'gunlist': gunlist, 'rast': rast}
return render(request, "base.html", cta)
我想根据连接到它们的最后一个条目的更新时间在模板中对Basliks进行排序。 我怎样才能做到这一点?感谢。
答案 0 :(得分:0)
在添加输入功能时,我添加了这部分代码并解决了。
baslik.updated = entry.updated
baslik.save()