fanfanacs 2023-03-01 11: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 11: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月9日
  • 已采纳回答 3月1日
  • 创建了问题 3月1日

悬赏问题

  • ¥500 高有偿提问!求优化设计微信小程序
  • ¥15 matlab在安装时报错 无法找到入口 无法定位程序输入点
  • ¥15 收益高的广告联盟有哪些
  • ¥15 Android Studio webview 的使用问题, 播放器横屏全屏
  • ¥15 删掉jdk后重新下载,Java web所需要的eclipse无法使用
  • ¥15 uniapp正式环境中通过webapi将本地数据推送到设备出现的跨域问题
  • ¥15 xui建立节点,显示错误
  • ¥15 关于#单片机#的问题:开始、复位、十进制的功能可以实现,但是切换八进制的功能无法实现(按下按键也没有效果),把初始状态调成八进制,也是八进制可以实现但是切换到十进制不行(相关搜索:汇编语言|计数器)
  • ¥15 VINS-Mono或Fusion中feature_manager中estimated_depth是特征的深度还是逆深度?
  • ¥15 谷歌浏览器如何备份抖音网页数据