fanfanacs 2023-03-01 03:20 采纳率: 100%
浏览 78
已结题

'set' object has no attribute 'count'

在进行搜索功能实现的时候,我用set将building_result和coperation_result两个搜索结果集合在了一起,然后在计算集合的数量时候,报错

AttributeError at /search/
'set' object has no attribute 'count'

from django.shortcuts import render
from myadmin.models import Building
from myadmin.models import Corporation
from django.db.models import Q
# Create your views here.

def index(request):
    ''' 项目前段,企业搜索'''
    return render(request,"web/index.html")

def search(request,pIndex=1):
   search_word = request.GET.get('wd', '')    # 获取到wd这个参数
   building_result = Building.objects.filter(Q(name__contains=search_word))# __contains= 部分匹配
   coperation_result = Corporation.objects.filter(Q(name__contains=search_word))  
   tmp_content_list = set()
   if building_result:
       tmp_content_list = set(building_result)

   # 最后将符合条件的文章标题模型和文章内容模型合并返回
   info_list = set()
   if coperation_result:
       info_list = set(coperation_result)

   # 在从文章标题模型中查找出最终汇总的模型返回
   search_result = info_list.union(tmp_content_list)



   context = {'search_word':search_word,  'search_result':search_result, 'search_result_count':search_result.count()}
   return render(request, 'web/search.html',context)
不知道该怎么该才可以获得计数统计。

展开全部

  • 写回答

4条回答 默认 最新

  • CodeBytes 2023-03-01 03:25
    关注

    该回答引用ChatGPT

    修正代码如下:

    from django.shortcuts import render
    from myadmin.models import Building
    from myadmin.models import Corporation
    from django.db.models import Q
    
    def index(request):
        ''' 项目前段,企业搜索'''
        return render(request, "web/index.html")
     
    def search(request, pIndex=1):
        search_word = request.GET.get('wd', '')    # 获取到wd这个参数
        building_result = Building.objects.filter(Q(name__contains=search_word))
        coperation_result = Corporation.objects.filter(Q(name__contains=search_word))  
        tmp_content_list = list(building_result)
        info_list = list(coperation_result)
        search_result = set(info_list).union(set(tmp_content_list))
        context = {'search_word': search_word, 'search_result': search_result, 'search_result_count': len(search_result)}
        return render(request, 'web/search.html', context)
    
    
    

    在这个修正的代码中,我们使用了len()函数来计算集合中的元素数量。此外,我们还使用了列表类型来存储搜索结果,而不是使用集合类型。在最后合并搜索结果时,我们将两个列表转换为集合并进行合并操作。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)
编辑
预览

报告相同问题?

问题事件

  • 系统已结题 3月8日
  • 已采纳回答 3月1日
  • 创建了问题 3月1日

悬赏问题

  • ¥15 中国json地图的点击事件
  • ¥15 前端是实现管道重叠效果
  • ¥15 WIN10批处理删除指定该文件夹下的所有文件和文件夹bat
  • ¥20 如何延长抓取实时信号的时间
  • ¥15 C# 一个项目中引用了两个外部dll,这两个dll平台不相同什么解决?
  • ¥200 webots中人形机器人调试
  • ¥15 关于#ios#的问题:我如何证明我的iPhone手机在一段时间里面是处于关机状态的
  • ¥15 关于波形反演中torch相关框架程序
  • ¥15 大恒水星相机SDK二次开发遇到的问题
  • ¥15 centos7.9 shell统计数量问题