Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/html/74.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/ms-access/4.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python 如何使用模板(如Jinja2)将列值列表呈现到表中_Python_Html_Templates_Jinja2 - Fatal编程技术网

Python 如何使用模板(如Jinja2)将列值列表呈现到表中

Python 如何使用模板(如Jinja2)将列值列表呈现到表中,python,html,templates,jinja2,Python,Html,Templates,Jinja2,我试图做以下事情(不起作用,只是为了传达预期的行为): 其中col1_值彼此唯一 如何重写Jinja2模板以获得所需的表输出?是否可以不必转换col1_值、col2_值和col3_值的维度?如果不是的话,做转置的最具python风格的方式是什么?我认为您有三个列表col1\u值、col2\u值和col3\u值。在视图中,将列表列表构造为: col_values = zip(col1_values, col2_values, col3_values) 将col_值传递给模板并执行以下操作: &l

我试图做以下事情(不起作用,只是为了传达预期的行为):

其中col1_值彼此唯一


如何重写Jinja2模板以获得所需的表输出?是否可以不必转换col1_值、col2_值和col3_值的维度?如果不是的话,做转置的最具python风格的方式是什么?

我认为您有三个列表col1\u值、col2\u值和col3\u值。在视图中,将列表列表构造为:

col_values = zip(col1_values, col2_values, col3_values)
将col_值传递给模板并执行以下操作:

<table>
  <tr>
    <th>Column 1</th>
    <th>Column 2</th>
    <th>Column 3</th>
  </tr>

  {% for col1, col2, col3 in col_values %}
    <tr>
      <td>{{ col1 }}</td>
      <td>{{ col2 }}</td>
      <td>{{ col3 }}</td>
    </tr>
  {% endfor %}
</table>

第1栏
第2栏
第3栏
{Colu值%中col1、col2、col3的百分比}
{{col1}}
{{col2}}
{{col3}}
{%endfor%}

我认为这是解决你问题的简单方法。希望有帮助。

为什么不使用嵌套列表呢?在结构上循环,如:

table_values = [[col1_value_0, col2_value_0, col3_value_0], [col1_value_1, col2_value_1, col3_value_1], ...]
如果需要,可以组合3个colX_值列表:

table_rows = zip(col1_values, col2_values, col3_values)
现在您有了要循环的每行列表:

{% for col1_val, col2_val, col3_val in table_rows %}
  <tr>
    <td>{{ col1_val }}</td>
    <td>{{ col2_val }}</td>
    <td>{{ col3_val }}</td>
  </tr>
{% endfor %}
{表%u行中col1\u val、col2\u val、col3\u val的百分比}
{{col1_val}}
{{col2_val}}
{{col3_val}}
{%endfor%}

它不是{{col1_val}吗?不是。是的,你说得对,谢谢。已经更正了。为什么不改为使用嵌套列表<代码>表格_值=[[col1_值_0,col2_值_0,col3_值_0],[col1_值_1,col2_值_1,col3_值_1],…]?
zip()
函数可以根据需要组合3个
colX\u值
列表。@MartijnPieters我将
zip(col1\u值、col2\u值、col3\u值)作为
行值
传递到模板中,并从
{%for row_values%}
loop,它工作得很好。非常感谢!我尝试了这个方法,但是在for循环中出现了一个解包错误:“ValueError:太多的值无法解包”您确定代码中有这样的内容:col_values=[col1_值,col2_值,col3_值]。其中应该列出col1\u值、col2\u值、col3\u值。是的,我认为您的代码缺少zip()步骤…
col\u values=zip(col1\u值、col2\u值、col3\u值)
table_rows = zip(col1_values, col2_values, col3_values)
{% for col1_val, col2_val, col3_val in table_rows %}
  <tr>
    <td>{{ col1_val }}</td>
    <td>{{ col2_val }}</td>
    <td>{{ col3_val }}</td>
  </tr>
{% endfor %}