我有这个结构,
index.py
run.py
app/
__init__.py
routes.py
templates/
...
index.py,
import os
import sys
activate_this = os.path.dirname(__file__) + '/venv/Scripts/activate_this.py'
exec(open(activate_this).read(), dict(__file__ = activate_this))
# Expand Python classes path with your app's path.
sys.path.insert(0, os.path.dirname(__file__))
from run import app
#Initialize WSGI app object.
application = app
run.py,
from flask import Flask
app = Flask(__name__)
from app import routes
if __name__ == '__main__':
app.run()
应用程序/ routes.py,
from run import app
from flask import Flask, render_template
@app.route('/')
def hello_world():
return 'Hello World'
@app.route('/dave')
def myDave():
return 'Hello World - From Dave'
@app.route('/home')
def home():
return render_template('home.html')
@app.route('/about')
def about():
return render_template('about.html')
应用程序/ __init__.py
,
(blank)
因此,当我使用/
访问该应用时,我得到Hello World
这是正确的,/dave
我得到Hello World - From Dave
但是对于/home
和/about
,我得到 500内部服务器错误
日志文件根本没有提供有关错误的详细信息,
[8月21日星期五19:47:06.992431 2015] [mpm_winnt:notice] [pid 7036:tid [244] AH00418:父母:创建子过程5872 [8月21日星期五 19:47:07.257631 2015] [wsgi:warn] [pid 5872:tid 244] mod_wsgi: 编译为Python / 2.7.9 +。 [8月21日星期五19:47:07.257631 2015] [wsgi:warn] [pid 5872:tid 244] mod_wsgi:使用Python / 2.7.10运行时。 [[8月21日星期五19:47:07.273231 2015] [mpm_winnt:notice] [pid 5872:tid [244] AH00354:Child:启动64个工作线程。
但似乎Flask的模块render_template
未加载或无效。
任何想法我做错了什么?
答案 0 :(得分:4)
Flask默认使用'模板'应用程序根路径上的文件夹。
根据您现有的设置,您可以在run.py
中实例化您的Flask应用:
project_root = os.path.dirname(__file__)
template_path = os.path.join(project_root, 'app/templates')
app = Flask(__name__, template_folder=template_path)