Django搜索排序

Django提供了一个SearchQuery类把查询词转换为一个搜索查询对象。

使用全文搜索的实例,根据查询词出现的频率和它们之间的距离对结果进行排序。

关于全文搜索更多内容,请看Django全文搜索-CSDN博客

相关性排序

编辑views.py,添加以下导入

python 复制代码
from django.contrib.postgres.search import SearchVector,SearchQuery,SearchRank

找到post_search

python 复制代码
            results = Post.objects.annotate(
                search = SearchVector('title','body'),
             ).filter(search=query)

替换为

python 复制代码
             search_vector = SearchVector('title','body')
             search_query = SearchQuery(query)
             results = Post.objects.annotate(
                 search = search_vector,
                 rank = SearchRank(search_vector,search_query)
             ).filter(search=search_query).order_by('-rank')

创建一个SearchQuery对象,通过它过滤结果,并使用SearchRank按相关性对结果排序。

  • SearchVector:在哪里查询
  • SearchQuery:查询词是什么
  • SearchRank:如何排序

权重排序

在按相关性排序结果时赋予它们更多权重。

例如,按标题而不是按内容匹配的帖子提供更多相关性。

编辑views.py

python 复制代码
            search_vector = SearchVector('title',weight='A') + SearchVector('body',weight='B')
            search_query = SearchQuery(query)
            results = Post.objects.annotate(
                search = search_vector,
                rank = SearchRank(search_vector,search_query)
            ).filter(rank__gte=0.3).order_by('-rank')

使用title和body字段构建的搜索向量应用了不同的权重。

默认权值为D(0.1),C(0.2),B(0.4),A(1.0)

示例对标题的搜索权重为1,对正文的权重为0.4。所以标题匹配讲优先于正文匹配。

对结果进行过滤,只显示排名高于0.3的结果。

最终查询方法代码示例

python 复制代码
def post_search(request):
    form = SearchForm()
    query = None
    results = []
    if 'query' in request.GET:
        form = SearchForm(request.GET)
        if form.is_valid():
            query = form.cleaned_data['query']
            
            search_vector = SearchVector('title',weight='A') + SearchVector('body',weight='B')
            search_query = SearchQuery(query)
            results = Post.objects.annotate(
                search = search_vector,
                rank = SearchRank(search_vector,search_query)
            ).filter(rank__gte=0.3).order_by('-rank')
    template = "blog/post/search.html"
    context={
        'form':form,
        'query':query,
        'results':results,
    }
    return render(request,template,context)

关于全文搜索的表单类,模版和路径的构建,请查看Django全文搜索-CSDN博客

相关推荐
知乎的哥廷根数学学派6 小时前
面向可信机械故障诊断的自适应置信度惩罚深度校准算法(Pytorch)
人工智能·pytorch·python·深度学习·算法·机器学习·矩阵
且去填词6 小时前
DeepSeek :基于 Schema 推理与自愈机制的智能 ETL
数据仓库·人工智能·python·语言模型·etl·schema·deepseek
人工干智能7 小时前
OpenAI Assistants API 中 client.beta.threads.messages.create方法,兼谈一星*和两星**解包
python·llm
databook7 小时前
当条形图遇上极坐标:径向与圆形条形图的视觉革命
python·数据分析·数据可视化
阿部多瑞 ABU7 小时前
`chenmo` —— 可编程元叙事引擎 V2.3+
linux·人工智能·python·ai写作
acanab7 小时前
VScode python插件
ide·vscode·python
知乎的哥廷根数学学派8 小时前
基于生成对抗U-Net混合架构的隧道衬砌缺陷地质雷达数据智能反演与成像方法(以模拟信号为例,Pytorch)
开发语言·人工智能·pytorch·python·深度学习·机器学习
WangYaolove13148 小时前
Python基于大数据的电影市场预测分析(源码+文档)
python·django·毕业设计·源码
知乎的哥廷根数学学派9 小时前
基于自适应多尺度小波核编码与注意力增强的脉冲神经网络机械故障诊断(Pytorch)
人工智能·pytorch·python·深度学习·神经网络·机器学习
cnxy18810 小时前
Python爬虫进阶:反爬虫策略与Selenium自动化完整指南
爬虫·python·selenium