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

'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()函数来计算集合中的元素数量。此外,我们还使用了列表类型来存储搜索结果,而不是使用集合类型。在最后合并搜索结果时,我们将两个列表转换为集合并进行合并操作。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
    fanfanacs 2023-03-01 03:35

    感谢,'set' object is not subscriptable又该怎么办呢?

    回复
    CodeBytes 回复 fanfanacs 2023-03-01 03:38

    该回答引用ChatGPT

    当您尝试对一个集合(set)使用下标操作时,就会引发“'set' object is not subscriptable”异常。这是因为集合(set)是一个无序的不可重复的集合,不支持下标操作。如果您需要按照特定的顺序访问元素,那么您应该使用列表(list)类型。

    下面是一个示例,演示了如何在代码中出现“'set' object is not subscriptable”异常时进行修复。

    my_set = set([1, 2, 3, 4, 5])
    # 错误的方式,尝试使用下标访问集合元素
    print(my_set[0])  # 引发异常:'set' object is not subscriptable
     
    # 正确的方式,将集合转换为列表
    my_list = list(my_set)
    print(my_list[0])  # 输出 1
    
    

    在上面的代码中,我们定义了一个集合my_set,然后尝试使用下标[0]访问集合中的第一个元素,这会引发“'set' object is not subscriptable”异常。为了修复这个问题,我们可以使用列表(list)类型来存储集合中的元素,然后使用下标来访问它们。在上面的代码中,我们使用list()函数将集合转换为列表,并使用my_list[0]来访问列表中的第一个元素,这会输出1。

    回复
    fanfanacs 回复 CodeBytes 2023-03-01 03:42

    感谢感谢

    回复
查看更多回答(3条)
编辑
预览

报告相同问题?

问题事件

  • 系统已结题 3月8日
  • 已采纳回答 3月1日
  • 创建了问题 3月1日
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部