Flask | 创建项目 + 配置

133 阅读1分钟

什么是Flask

创建Flask项目

app.py 模版

from flask import Flask  
  
app = Flask(__name__)  
  
@app.route('/')  
def hello_world():  
    return 'Hello World'  
  
if __name__ == '__main__':  
    app.run()

配置文件

debug模式:

开启debug模式后,就会自动加载,不需要手动重启项目

如果开发的时候,出现Bug, 如果开启了debug模式,那我们在浏览器上也可以看到报错信息

如果你是社区版本,你可以直接加上 debug=True 就好

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

修改host:

host是我们监听的主机名。如果想让别的电脑访问到我们的项目,我们直接修改host就好

在编译里面修改,如图

image.png

修改端口号:

默认监听5000端口。如果端口被被其他程序占用,我们该如何修改呢?

通过修改:

--host=0.0.0.0 --port=8000

image.png

image.png

这样我们就可以监听我们修改后所要监听的端口。

配置路由

可以直接添加

@app.route('/login/')  
def login():  
    return 'This is LOGIN page'  
  
@app.route('/register/')  
def register():  
    return 'This is REGISTER page'

传参数添加

第一种方式:

@app.route('/blog/<int:blog_id>/')  
def blog_detail(blog_id):  
    return 'This is blog No.%s' % blog_id  

第二种方式:

@app.route('/book_list/')  
def book_detail():  
    page = request.args.get('page', default=1, type=int)  
    return f'这个第 {page} 页的图书列表'

http://127.0.0.1:8000/book_list/?page=3

渲染HTML文件

普通方式:

from flask import Flask, request, render_template  
  
@app.route('/')  
def hello_world():  
    return render_template("index.html")

用Jinja2给HTML文件传参数

@app.route('/blog/<int:blog_id>/')  
def blog_detail(blog_id):  
    return render_template("blog_detail.html", blog_id = blog_id)

过滤器(自定义)

def datetime_format(value, format="%Y年%d%m %H:%M):
    return value.strftime(format)
    
app.add_template_filter(datetime_format, "dformat)