当前登录用户Django的Queryset

时间:2018-10-16 18:23:24

标签: django django-views

我正在用我的模型进行查询。现在queryset在我的html页面中显示所有数据。但是我只想显示已登录的用户数据。

models.py

class Data(models.Model):
user = models.OneToOneField(User, on_delete=models.CASCADE)
Status = models.CharField(max_length=10, blank=False)
Date = models.DateField(blank=True, null=True)

views.py

@login_required
def search(request):
    status_list = Data.objects.all()
    status_filter = UserFilter(request.GET, queryset=status_list)
    return render(request, 'users/data.html', {'filter': status_filter})

filters.py

class UserFilter(django_filters.FilterSet):

class Meta:
    model = Data
    fields = {
        'Date': ['year','month', ], 'user': ['exact', ],
    }

我也尝试了不同的 views.py ,但是没有用。

@login_required
def search(request, user):

    status_list = Data.objects.get(user=self.request.user).search(query)
    status_filter = UserFilter(request.GET, queryset=status_list)
    return render(request, 'users/data.html', {'filter': status_filter})

data.html

<!DOCTYPE html>
{% load django_tables2 %}
{% load staticfiles %}
<html lang="en" dir="ltr">
  <head>
    <meta charset="utf-8">
    <title></title>

  </head>
  <body>

{% block content%}


      <form method="get">
        {{ filter.form.as_table }}
        </select>
        <button type="submit" class="btn btn-primary">
        <span class="glyphicon glyphicon-search"></span> Search
      </button>
      </form>
      <ul>
        {% for user in filter.qs %}
        <li>{{ user.username }} - {{ user.get_full_name }}</li>
        {% endfor %}
      </ul>

    <table id="datatable" style="margin-top: 20px" style="margin- 
    bottom:20px" class="table table-bordered" >
    <thead>
      <tr>
        <th>user</th>
        <th>EndDate</th>
        <th>Status</th>

      </tr>
    </thead>
    <tbody>
      {% for Data in filter.qs %}
        <tr>
          <td>{{ Data.user }}</td>
          <td>{{ Data.EndDate }}</td>
          <td>{{ Data.Status }}</td>
        </tr>
      {% empty %}
        <tr>
          <td colspan="5">No data</td>
        </tr>
      {% endfor %}
    </tbody>
    </table>


{% endblock content%}



  </body>

在上面我还添加了我的HTML代码。请也查看html代码。

4 个答案:

答案 0 :(得分:1)

您可以简化代码,django提供了许多帮助程序功能来帮助程序员。

在您的 views.py 中,您可以执行以下操作:

@login_required
def search(request):
    status_list = Data.objects.all()
    status_filter = status_list.filter(user=request.user) //get current user id
    return render(request, 'users/data.html', {'filter': status_filter})

答案 1 :(得分:1)

status_list = Data.objects.get(user=self.request.user) 

是错误的,因为self仅在基于类的视图中使用。难怪它没有用。 请尝试使用以下代码代替

status_list = Data.objects.filter(user=request.user) or 
status_list = Data.objects.get(user=request.user)

因此,最终代码将类似于

@login_required
def search(request):
    status_list = Data.objects.get(user=request.user)
    render(request, 'users/data.html', {'filter': status_list})

答案 2 :(得分:1)

下面的代码应该可以正常工作。

 {% for data in filter %}
     <li>{{ data.user.username }} - {{ data.user.get_full_name }}</li>
 {% endfor %}

 {% for Data in filter %}
    <tr>
      <td>{{ Data.user }}</td>
      <td>{{ Data.Date }}</td>
      <td>{{ Data.Status }}</td>
    </tr>
  {% empty %}

由于您不会使用过滤器,因此应删除filters.py。
这也行不通。根据需要进行更改。     {{filter.form.as_table}}

答案 3 :(得分:1)

可能会有更好的方法来做到这一点。由于您仍在学习下面的代码,因此可以解决问题。

@login_required
def search(request, *args, **kwargs):
    status_list = Data.objects.get(user=request.user)

    month = request.GET.get("month", None)
    year = request.GET.get("year", None)

    if month:
        status_list = status_list.filter(Date__month=month)

    if year:
        status_list = status_list.filter(Date__year=year)

    return render(request, 'users/data.html', {'filter': status_list})