这个问题的Part 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
报表属于报表模板。报表模板有许多报表。你知道吗
我对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
字段值通过用jinja2标记编写的markup
值放入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,
},
},
}
写在我的设置.py你知道吗
生成了调试.log你知道吗
但是调试.log都是空的
更新3:
需要明确更改
logger = logging.getLogger(__name__)
至
logger = logging.getLogger('reports.admin')
只需获取
template
模型的Report
字段:更新:在use the logger中,应在源文件的开头添加以下两行:
相关问题 更多 >
编程相关推荐