尝试将一个表插入烧瓶

时间:2016-08-04 23:10:25

标签: python html flask jinja2

我一直在尝试使用Jinja2中的超级简单模板创建我的第一个Flask网站。 (我开始使用我的常规HTML并快速放弃它,因为弄清楚把东西放在哪里是一场噩梦。我会在这个困难的部分之后再回过头来调整烧瓶代码,现在,我已经淘汰了一切但是html声明和试图放入表格。)

Flask Code:

from flask import Flask
from flask import render_template
import redis
from flask import json
from dateutils.parser import parse
from flask_table import Table, Col, DatetimeCol
r=redis.StrictRedis(host='localhost', port =6379, db=0)

app = Flask(__name__)

@app.route('/')
@app.route('/p/')
def p():
    raw = r.get('rData')
    raw= yaml.load(raw)
    raw = json.loads(raw)
    for item in raw:
         item['date_time'] = parse(item['date_time'])
    class ItemTable(Table):
        Sensor = Col("Sensor")
        date_time = DatetimeCol("Date & Time")
        Reading = Col("Reading")
    table = ItemTable(raw)
    return render_template('p.html'), table

if __name__ == '__main__':
    app.run()

此代码将在本地调用页面/ p和如果我要求它显示 raw它将打印出该表的数据(我已在下面包含)。

{{ raw }}

我收回了我的字典!

但是当我试图向表格展示时 ItemTable应该创建,它会崩溃我的页面或根本没有显示任何内容。我也试过这种方式使用返回码:

        return render_template('p.html', table=table)

将其作为完全执行的html的变量传递,没有什么好处。 {{ table }}

词典列表中的实际数据:

[{"date_time": "2016-08-03T14:00:00.000-04:00", "Reading": 27.5, "Sensor": "Water Temperature (degrees Celsius)"}, {"date_time": "2016-08-03T14:00:00.000-04:00", "Reading": 0.91, "Sensor": "Lake Gage Height (in feet)"}, {"date_time": "2016-08-03T14:00:00.000-04:00", "Reading": 53.0, "Sensor": "Specific Conductivity in microSiemens"}, {"date_time": "2016-08-03T14:00:00.000-04:00", "Reading": 7.3, "Sensor": "Dissolved Oxygen (ppm)"}, {"date_time": "2016-08-03T14:00:00.000-04:00", "Reading": 6.9, "Sensor": "pH (standard field)"}, {"date_time": "2016-08-03T14:00:00.000-04:00", "Reading": 27.7, "Sensor": "Air Temperature (in degrees Celsius)"}, {"date_time": "2016-08-03T14:00:00.000-04:00", "Reading": 2.5, "Sensor": "Wind Speed (in mph)"}, {"date_time": "2016-08-03T14:00:00.000-04:00", "Reading": 238.0, "Sensor": "Wind Direction (degrees CW from North)"}, {"Reading": 30.7, "Sensor": "Relative Humidity", "date-Time": "2016-08-03T14:00:00.000-04:00"}, {"date_time": "2016-08-03T14:00:00.000-04:00", "Reading": 1.26, "Sensor": "Marsh Gage Height in feet"}, {"date_time": "2016-08-03T14:00:00.000-04:00", "Reading": 0.01, "Sensor": "24 Cumulative Precipication (inches)"}]

我将其从我创建的redis缓存中拉出来,但您可以将raw=设置为上面的列表并替换它。

难题:

我需要在Jinja2中插入什么才能使表格显示在这两个return演示文稿中的一个,或者是否有其他方法告诉flask将转换后的字典列表移植到模板中?

我到处搜索,烧瓶桌上的页面没有显示如何在另一边展示它。

我的目标是将其放在一个容器中,该容器是基本布局的子容器。但只是让它显示为一张桌子就足够了,我可以从那里找出其余部分。

我可以创建最简单的HTML / Jinja模板:

<!doctype html>

<h1> test </h1>


{{table}}

我尝试使用{% table %}也无济于事。

我不确定问题是我是否在烧瓶中生成html并尝试将其发送到模板,或者我是否告诉Jinja如何呈现我已创建并包含在内的table元素render_template方法。

<h1> test </h1>只是为了让我在发送表格时看到页面是否完全呈现。这不重要。

我认为我遇到的问题是大多数教程都过于简化,每组文档(Flask&amp; Jinja2)都很清楚等式的另一面。我在两页上找到了flask-table ONE 解释但是相同的东西。没有提出用模板调用它的建议。

更新

我现在运行时遇到KeyError:更改如下:

    raw= yaml.load(raw) #new to make a list for reading after next line
    raw = json.loads(raw) #makes it iterable in UTF-8
    for item in raw:
         item['date_time'] = parse(item['date_time']) #creates dates but throws 
    errors which stops flask

新编辑:json.loads之后的部分数据:

 [{u'Reading': 25.9,
  u'Sensor': u'Water Temperature (degrees Celsius)',
  u'date_time': u'2016-08-05T08:45:00.000-04:00'},
 {u'Reading': 0.88,
  u'Sensor': u'Lake Gage Height (in feet)',
  u'date_time': u'2016-08-05T08:45:00.000-04:00'}]

数据解析后[&#39; date_time&#39;]:

raw[1]['date_time']
datetime.datetime(2016, 8, 5, 8, 45, tzinfo=tzoffset(None, -14400))

新更新:我错过了date_time字段中的大写 T ,因此更正了修复KeyError ...但我仍然无法得到它传递给HTML。我得到了一大堆涉及文件夹和文件的行,然后我得到:

AttributeError: 'NoneType' object has no attribute 'datetime_formats'

为什么日期和时间如此有趣?

1 个答案:

答案 0 :(得分:1)

您需要将时间戳转换为日期时间对象

from dateutil.parser import parse # pip install python-dateutil

raw = json.loads(raw)
for item in raw:
    item['date_time'] = parse(item['date_time'])

并将table传递给模板

return render_template('p.html', table=table)

Upd:所有项目都必须有date_time密钥。您的示例中的某些项目改为date-Time