Queryset for current logged in user Django

僤鯓⒐⒋嵵緔 提交于 2019-12-04 01:55:51

问题


I am doing queryset with my model. Now the queryset is displaying all the data in my html page. But I want to display only the logged in users data.

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', ],
    }

I tried with different views.py also but it didn't work.

@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>

Above I added my HTML code also.Please look into html code also.


回答1:


Below code should work fine.

 {% 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 %}

As you would not be using filters, so filters.py should be removed.
This will also not work. Make the changes as required. {{ filter.form.as_table }}




回答2:


You can simplify your code, django provides many helpers function to help to programmer.

in your views.py you can do:

@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})



回答3:


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

is wrong as self is only used in class based views. No wonder it did not work. Please try with the below code instead

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

So, the final code will be like

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



回答4:


There could be better ways to do this. As you are still learning below code does the trick.

@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})


来源:https://stackoverflow.com/questions/52841779/queryset-for-current-logged-in-user-django

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!