此问题的第2部分分别提出和回答。
我有一个Report
和一个ReportTemplate
。
+----+----------+---------------+-------------+
| id | title | data | template_id |
+----+----------+---------------+-------------+
| 1 | report 1 | {data: [...]} | 1 |
+----+----------+---------------+-------------+
reports table
+----+-----------+---------------+------------+
| id | title | markup | css |
+----+-----------+---------------+------------+
| 1 | template1 | <doctype!>... | body {.... |
+----+-----------+---------------+------------+
templates table
报表属于ReportTemplate。一个ReportTemplate有很多Report。
我有一个admin.py
名为的自定义管理员操作print_as_pdf
class ReportAdmin(admin.ModelAdmin):
fields = ['commodity',
'date',
'trade_period',
'quantity_cutoff',
'data',
'template',
'title']
actions = ['print_as_pdf']
def print_as_pdf(self, request, queryset):
return
print_as_pdf.short_description = 'Generate as pdf'
这些是模型:
class ReportTemplate(models.Model):
title = models.CharField(max_length=50)
markup = models.TextField(default = 'markup here...')
styles = models.TextField(default = 'styles here...')
# __unicode__ on Python 2
# __str__ on Python 3
def __unicode__(self):
return self.title
class Report(models.Model):
title = models.CharField(max_length=50)
commodity = models.CharField(max_length=10)
date = models.DateTimeField('date traded')
trade_period = models.CharField(max_length=10, default='open')
quantity_cutoff = models.IntegerField(default=0)
printed = models.BooleanField(default=0)
datetime_email_sent = models.DateTimeField('date email sent', blank=True, null=True)
data = models.TextField(default = 'data here...')
template = models.ForeignKey(ReportTemplate)
我想做的是:
markup
字段值data
报告的字段值通过markup
使用jinja2标记编写的值1放入我陷入了第一步。
给出的参数self
,request
,queryset
,我怎么检索相关ReportTemplate及其markup
字段值?
更新1:
我试图以此来测试给出的答案之一。
import logging
logger = logging.getLogger(__name__)
# .... code here ...
def print_as_pdf(self, request, queryset):
for report in queryset:
markup = report.template.markup
logger.debug(markup)
return
更新2:
# Logging
LOGGING = {
'version': 1,
'disable_existing_loggers': False,
'handlers': {
'file': {
'level': 'DEBUG',
'class': 'logging.FileHandler',
'filename': '/var/virtual/WebApps/virtualenvs/WeasyPrintProject/weasyprint_site/debug.log',
},
},
'loggers': {
'reports.admin': {
'handlers': ['file'],
'level': 'DEBUG',
'propagate': True,
},
},
}
在我的settings.py中写了这个
生成一个debug.log
但是,debug.log的内容为空
更新3:
需要明确改变
logger = logging.getLogger(__name__)
到
logger = logging.getLogger('reports.admin')
只需获取模型的template
字段即可Report
:
def print_as_pdf(self, request, queryset):
for report in queryset:
markup = report.template.markup
...
print_as_pdf.short_description = 'Generate as pdf'
更新:要使用记录器,应在源文件的开头添加以下两行:
import logging
logger = logging.getLogger(__name__)
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句