我需要在我的app.py
中的多个@ app.route中访问我的WTForm中的信息,以便我可以为我的应用发布数据可视化。目前,我有一个@app.route(/home/)
页面,此页面上的用户输入文本由WTForm处理,然后传递到@app.route(/results/
)我的代码进行一些数据分析,然后1)显示一些结果和2)将一些其他信息保存到JSON,JSON将在其自己的@app.route(/visualization/)
中用于D3。由于Javascript的复杂性,我想在自己的iframe
中显示我的D3可视化。现在我可以加载/home/
页面,输入文字并点击"提交"然后将我重定向到/results/
,并打印除iframe
以外的所有内容。问题是:我无法让@app.route(/visualization/)
从我的WTForm获取信息(与results
能够的方式相同),因此图像可以加载正确的JSON文件。
这里有一些我的代码可以更好地说明问题。
app.py
:
# Home
@app.route("/home/", methods=["GET", "POST"])
def gohome():
error = None
with open('somedata.pickle', 'rb')as f:
some_content = pickle.load(f)
try:
if request.method == "POST":
attempted_pmid = request.form['pmid']
except Exception as e:
#flash(e)
return render_template("dashboard.html", error=error)
return render_template("dashboard.html", some_content=some_content)
# My WTForm for handling user-entered pmids
class pmidForm(Form):
pmid = TextField('PubmedID')
# Results
@app.route("/results/", methods=["GET", "POST"])
def trying():
form = pmidForm(secret_key='potato')
try:
if request.method == 'POST':
entry = form.pmid.data #THIS IS THE USER INPUT FROM THE FORM #referencing 'class pmidForm'
pmid_list = multiple_pmid_input(entry) #list for handling multiple pmids
print(pmid_list)
for user_input in pmid_list:
print(str(user_input))
user_input = str(user_input)
# DO STUFF HERE #
# SAVE A JSON FILE TO A FOLDER #
return render_template('results.html')
except Exception as e:
return(str(e))
# Visualization
@app.route('/visualization/', methods=["GET", "POST"]) #for iframe
def visualization():
#need to get last user_input
form = pmidForm(secret_key='potato')
try:
if request.method == 'POST':
entry = form.pmid.data
pmid_list = multiple_pmid_input(entry)
for user_input in pmid_list:
print("This is the user input on /visualization/")
print(str(user_input))
user_input = str(user_input)
#Load
if user_input == pmid_list[-1]:
load_path = '/the/path/'+str(user_input)+'/'
completeName = os.path.join(load_path, ((str(user_input))+'.json'))
print(completeName)
with open(completeName, 'w') as load_data:
jsonDict = json.load(load_data)
print(jsonDict)
return render_template('visualization.html', jsonDict=jsonDict)
except Exception as e:
return(str(e))
因此我现在拥有它,home
和results
与我现有的WTForm一起工作正常。我会做好一切。但是在results.html
我需要在visualization.html
中加载iframe
,如下所示:
排队results.html
:
<iframe id="vis1" src="https://www.website.com/visualization/" width="1000" height="1000"></iframe>
使用此配置,如果我运行app.py
,除了iframe
显示之外,一切都显示正常:
本地变量&#39; jsonDict&#39;在分配前引用
在这里,我假设我参考了具有Jinja代码的visualization.html
:
var myjson = {{ jsonDict|tojson }};
很明显@app.route(/visualization/)
并没有得到WTForm的信息。我怎样才能获得第二个@app.route
来识别WTForm中的内容,例如它如何与results
一起使用?
此外,这可能看起来很糟糕,但我有充分理由将我的D3放入iframe
。这是因为我需要能够切换多个html,如/visualization
/,每个都有复杂的Javascript,彼此之间存在冲突。我能做的最好的事情是将它们全部隔离在iframe
中。
答案 0 :(得分:0)
答案是否定的,您不能将一个表单提交给多个路由或在多个路由之间共享数据。我解决了需要在多个路由之间共享数据的问题是创建动态URL。因此,不是总是转到results
页面,而是转到results/1234
,这样我就可以访问“1234”并在该html中使用它。