gpt4 book ai didi

python - django-tables2 ->如何完成获取多行单元格

转载 作者:太空宇宙 更新时间:2023-11-03 21:18:53 25 4
gpt4 key购买 nike

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

我正在显示的类(class):

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 %}

最后是 View :

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 中,但不渲染以获得多行。

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

最佳答案

找到了解决办法,放弃自定义列,使用“TemplateColumn”,以“{{record.enum|linebreaksbr }}”为模板。在我看来,使用字符串而不是字典,在字典条目之间使用 '\n' 。

View 中新的枚举生成是:

    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 }}")

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

关于python - django-tables2 ->如何完成获取多行单元格,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54467820/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com