使用django queryset更新函数和User foreignkey

时间:2011-08-18 13:37:57

标签: django foreign-keys django-queryset

总结:我有一个包含pdf对象的mysql db表。当用户打印其中一个时,我希望使用时间,日期,打印的布尔值以及打印pdf对象的用户更新表。此用户信息应该为当前登录的用户写入值。当打印pdf时,除了用户之外,我当前正在更新所有这些信息。我尝试过使用request.user,但这似乎不适用于查询集,否则我错过了一些东西。我也尝试使用类似于我如何定义get_user的方法,它允许我手动设置用户,但同样,不在查询集中自动更新。任何帮助深表感谢!我的admin.py文件如下:

from django.contrib import admin
from django.contrib.auth.models import User
from djangostuff.pdf.models import ABC
from django.http import HttpResponse
import datetime, time

class ABCAdmin(admin.ModelAdmin):

    actions = ['print_selected_pdf']

    def get_user(self):
        return '%s'%(self.user.username)

    def create_pdf(self, queryset):
        response = HttpResponse(mimetype="application/pdf")
        response['Content-Disposition'] = 'attachment; filename=form.pdf'
        for obj in queryset:
            response.write(obj.form)
            ABC.objects.filter(pk=obj.pk).update(pdf_printed="1",request_time=time.strftime("%H:%M:%S"),request_date=datetime.datetime.today())
            ABC.objects.filter(pk=obj.pk).update(user=request.user)

        return response


    def print_selected_pdf(self, request, queryset):
        # prints the pdfs for those that are selected,
        # regardless if the pdf_printed field is true or false
        qs = queryset.filter(pdf_printed__exact=0)
        return self.create_pdf(qs)

    print_selected_pdf.short_description = "Print Selected PDF"

    get_user.short_description='Printed By'

    list_display=('form_no',get_user,'request_date','request_time','pdf_printed')


admin.site.register(ABC, ABCAdmin)

1 个答案:

答案 0 :(得分:2)

为什么不将request作为参数传递给create_pdf

def create_pdf(self, request, queryset):
    ...

def print_selected_pdf(self, request, queryset):
    qs = queryset.filter(pdf_printed__exact=0)
    return self.create_pdf(request, qs)