【转】Django模糊查询

  1. def search(request):  
  2.     searchtype = request.POST.get("searchtype")  
  3.     keyword = request.POST.get("keyword")  
  4.     if searchtype == "all":  
  5.         #多个字段模糊查询, 括号中的下划线是双下划线,双下划线前是字段名,双下划线后可以是icontains或contains,区别是是否大小写敏感,竖线是或的意思  
  6.         sciencenews = models.Sciencenews.objects.filter(Q(title__icontains=keyword)\  
  7.         |Q(content__icontains=keyword)|Q(author__icontains=keyword))  
  8.     elif searchtype == "author":  
  9.         #单个字段模糊查询  
  10.         sciencenews = models.Sciencenews.objects.filter(author__icontains=keyword)  
  11.     elif searchtype == "title":  
  12.         sciencenews = models.Sciencenews.objects.filter(title__icontains=keyword)  
  13.     elif searchtype == "content":  
  14.         sciencenews = models.Sciencenews.objects.filter(content__icontains=keyword)  
  15.     else:  
  16.         #使用点连接的filter链表示and  
  17.         sciencenews = models.Sciencenews.objects.filter(author__icontains=keyword).\  
  18.             filter(title__icontains=keyword).filter(content__icontains=keyword)  
  19.           
  20.     return render(request,"show/index.html",{"param":sciencenews,"searchtype":searchtype,"keyword":keyword})  

 

  #多个字段模糊查询, 括号中的下划线是双下划线,双下划线前是字段名,双下划线后可以是icontains或contains,区别是是否大小写敏感,竖线是或的意思sciencenews = models.Sciencenews.objects.filter(Q(title__icontains=keyword)|Q(content__icontains=keyword)|Q(author__icontains=keyword))

posted @ 2017-11-29 10:49  清源如风  阅读(3016)  评论(1编辑  收藏  举报