【转】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))


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM