【问题标题】:argument of type 'NoneType' is not iterable for django string " "'NoneType' 类型的参数对于 django 字符串“”是不可迭代的
【发布时间】:2019-08-23 06:39:04
【问题描述】:

我正在尝试根据空格 " " 拆分我的查询。例如 first_name last_name 但是如果我尝试检查搜索中的空格,我会收到错误

“NoneType”类型的参数不可迭代

if ' ' in query: #This is where is the error is generated

正在尝试解决上述问题。下面是整个代码

class QList(SelectRelatedMixin, ListView):
    model = Question

    def get_queryset(self):
        queryset = super(QList, self).get_queryset().order_by('-created_at')
        query = self.request.GET.get('q')

        if ' ' in query:
            query = query.split()
            queryset = queryset.filter(
                chain(User.objects.filter(first_name__icontains=query[0], last_name__icontains=query[1]),
                      User.objects.filter(first_name__icontains=query[1], last_name__icontains=query[0])))

            return queryset
        else:
            queryset = queryset.filter(
                Q(user__username__iexact=query) |
                Q(user__first_name__iexact=query) |
                Q(user__last_name__iexact=query)

                )
        return queryset

任何人都可以提出解决方法

【问题讨论】:

  • 您要检查的内容。 queryif ' ' in query 中是否为空?
  • @ShafikurRahman 只想分开first_name" "last_name。因此,如果两个字之间有 space" "。第一个单词成为第一个名字,第二个单词成为姓氏

标签: django python-3.x django-views django-queryset


【解决方案1】:

要拆分字符串,只需说你的名字是“Marco Bianchi”。

query = "Marco Bianchi"
first_name = query.split(" ")[0]
last_name = query.split(" ")[1]

更新: 而不是

if ' ' in query:
     query = query.split()

使用这个

query = query.split(" ")

【讨论】:

    【解决方案2】:

    您可以使用拆分字符串,例如:

    class QList(SelectRelatedMixin, ListView):
    model = Question
    
    def get_queryset(self):
        queryset = super(QList, self).get_queryset().order_by('-created_at')
        query = self.request.GET.get('q')
    
        query = query.split()
    
        if len(query) == 2:
            queryset = queryset.filter(
            chain(User.objects.filter(first_name__icontains=query[0], last_name__icontains=query[1]),
                  User.objects.filter(first_name__icontains=query[1], last_name__icontains=query[0])))
        else:
            queryset = queryset.filter(
                Q(user__username__iexact=query) |
                Q(user__first_name__iexact=query) |
                Q(user__last_name__iexact=query)
    
                )
    
        return queryset
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2017-01-07
      • 2011-10-04
      • 2016-04-06
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多