我一直在尝试使用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'
为什么日期和时间如此有趣?
答案 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
。