【问题标题】:django-table2 ->how to accomplish getting a multiline celldjango-table2 -> 如何完成获取多行单元格
【发布时间】:2020-08-19 07:44:08
【问题描述】:

我的表中有一个列(基于一个类,而不是模型类)是一个 python Dict 对象,我希望它的列中的单元格显示为每个 dict 条目一行。

我正在展示的课程:

class MegaDatapoint:

def __init__(self, id=None,
             name=None,
             display_name=None,
             description=None,
             enum_dict=None,

             ):

    self.id = id
    self.name = name
    self.display_name = display_name
    self.description = description
    self.enum_dict = enum_dict

在我的 tables.py 中,我有以下内容:

class DictColumn(tables.Column):
    def render(self, value):

        if type(value) is dict:
            v = ""
            for d in value:
                v += f"{d}->{value[d]}\n\r"
        else:
            v = "--"
        return v


class MegaTable(tables.Table):

    name = tables.Column()
    display_name = tables.Column()
    description = tables.Column()
    enum_dict = DictColumn(attrs={'td': {' white-space':'pre-wrap'} })

模板“megadatapoint_table2.html”是:

{% extends "base.html" %}
{% load render_table from django_tables2 %}
{% block title %}{{ block.super }}Projects{% endblock %}
{% block container %}
    <div>
        <title>List of Datapoints</title>
        <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" />
    </div>
    <div>
        {% render_table table %}
    </div>
{% endblock %}

最后是视图:

class MegadatapointTableView(SingleTableView):
table_class = MegaDatapointTable
template_name = 'megadatapoint_table2.html'


def get_queryset(self):

    """
    Return the product features for this product
    """
    self.enums = Enumeration.objects.all().order_by('enumeration_group')
    self.enum_values_dict = {}
    for enum in self.enums:

        if enum.enumeration_group.id not in self.enum_values_dict:
            self.enum_values_dict[enum.enumeration_group.id] = {}
        self.enum_values_dict[enum.enumeration_group.id][enum.ordinal] = enum.name
    self.m_dp_list = []

    for dp in Datapoint.objects.all():
        dp_enum_dict = None
        if dp.enumeration_group is not None:
            if dp.enumeration_group.id in self.enum_values:
                dp_enum_dict = self.enum_values_dict[dp.enumeration_group.id]
            else:
                dp_enum = f"opps, no enumeration in DB->{dp.enumeration_group.id}"
        else:
            dp_enum = ""

        mdp = MegaDatapoint(id=dp.id,
                            name=dp.name,
                            display_name=dp.display_name,
                            description=dp.description,
                            enum_dict=dp_enum_dict,

                            )
        self.m_dp_list.append(mdp)

    return self.m_dp_list

列属性显示在 HTML 中,但不渲染以获取多行。

任何线索或帮助将不胜感激......

【问题讨论】:

    标签: python django django-tables2


    【解决方案1】:

    找到解决方案,放弃自定义列,使用带有“{{record.enum|linebreaksbr }}”的“TemplateColumn”作为模板。在我看来,使用字符串而不是 dict,在 dict 条目之间使用 '\n'。

    所以视图中的新枚举生成是:

        self.enums = Enumeration.objects.all().order_by('enumeration_group','ordinal')
        self.enum_values = {}
        for enum in self.enums:
    
            if enum.enumeration_group.id in self.enum_values:
                self.enum_values[enum.enumeration_group.id] += f"\n{enum.ordinal}->{enum.name }"
            else:
                self.enum_values[enum.enumeration_group.id] = f"{enum.ordinal}->{enum.name }"
    

    而新表是:

    class MegaDatapointTable(tables.Table):
    
       name = tables.Column(linkify=("fele:datapoints_detail", {"pk": tables.A("id")}))
       display_name = tables.Column()
       description = tables.Column()
       enum_group = tables.TemplateColumn("{{record.enum_group|linebreaksbr }}")
    

    我认为这也更干净一些......

    【讨论】:

      【解决方案2】:

      第一种方法应该可行,但你应该使用

      DictColumn(attrs={'td': {'style': 'white-space:pre-wrap;'} })
      

      而不是

      DictColumn(attrs={'td': {'white-space': 'pre-wrap'} })
      

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 2012-08-30
        • 2021-07-18
        • 2022-01-27
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2017-11-25
        相关资源
        最近更新 更多