总结:我有一个包含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)
答案 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)