1

我正在开发一个简单的关键字分组工具。我想按 SERP 中相同网址的数量对短语进行分组。

短语代表搜索引擎中的关键字。SerpEntry 代表网站上的链接。

我正在寻找一种方法来选择在 SerpEntry 中至少具有 N 个相同 url 的短语。

这是我的模型:

class Phrase(models.Model):
    text = models.CharField(max_length=1000, unique=True)
    _serp = models.OneToOneField(Serp, null=True, blank=True, related_name='phrase', db_column="serp")

class SerpEntry(models.Model):
    phrase = models.ForeignKey(Phrase, related_name='serp_entry')
    position = models.PositiveIntegerField()
    url = models.TextField(max_length=2000)
    title = models.CharField(max_length=100)
    snippet = models.TextField()

你对如何做到这一点有什么建议吗?

4

1 回答 1

1

像这样的东西可能会起作用:

Phrase.objects.filter(serp_entry__id__gt=0, #or whatever filter you need
            ).annotate(has_count=Count('id')
            ).order_by('serp_entry__phrase', #or whatever order you need
            ).filter(has_count__gt=100)
于 2016-05-11T21:21:03.453 回答