如何通过Django中的自定义管理操作获取关联模型?

2024-09-29 19:27:47 发布

您现在位置:Python中文网/ 问答频道 /正文

这个问题的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)

我想做的是:

  1. 检索关联的ReportTemplate及其markup字段值
  2. 将报表的data字段值通过用jinja2标记编写的markup值放入1中
  3. 使用weasyprint并将2中的数据填充标记打印为pdf

我被困在第一步。你知道吗

给定参数selfrequestqueryset,如何检索关联的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')

Tags: selfdefaultdatapdf报表admintitlemodels
1条回答
网友
1楼 · 发布于 2024-09-29 19:27:47

只需获取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'

更新:在use the logger中,应在源文件的开头添加以下两行:

import logging

logger = logging.getLogger(__name__)

相关问题 更多 >

    热门问题