qpython3ll使用教程_Python3+Flask安装使用教程详解

一、Flask安装环境配置

当前我的开发环境是Miniconda3+PyCharm。开发环境其实无所谓,自己使用Python3+Nodepad都可以。安装Flask库:

pip install Flask

二、第一个Flask应用程序

将以下内容保存为helloworld.py:

# 导入Flask类

from flask import Flask

# 实例化,可视为固定格式

app = Flask(__name__)

# route()方法用于设定路由;类似spring路由配置

@app.route('/helloworld')

def hello_world():

return 'Hello, World!'

if __name__ == '__main__':

# app.run(host, port, debug, options)

# 默认值:host="127.0.0.1", port=5000, debug=False

app.run(host="0.0.0.0", port=5000)

直接运行该文件,然后访问:http://127.0.0.1:5000/helloworld。结果如下图:

022375a96b37c3c32ae3e6d05d5c6266.png

三、get和post实现

3.1 创建用到的模板文件

Flask默认到templates目录下查找模板文件,在上边helloworld.py同级目录下创建templates文件夹。

在templates文件夹下创建get.html,写入以下内容:

get请求示例

再在templates文件夹下创建post.html,写入以下内容:

post请求示例

最后在templates文件夹下创建result.html,写入以下内容:

{{ result }}

3.2 编写相关的处理方法

在helloworld.py中添加get_html()、post_html()和deal_request()三个方法,更多说明见注释。当前helloworld.py内容如下:

# 导入Flask类

from flask import Flask

from flask import render_template

from flask import request

# 实例化,可视为固定格式

app = Flask(__name__)

# route()方法用于设定路由;类似spring路由配置

#等价于在方法后写:app.add_url_rule('/', 'helloworld', hello_world)

@app.route('/helloworld')

def hello_world():

return 'Hello, World!'

# 配置路由,当请求get.html时交由get_html()处理

@app.route('/get.html')

def get_html():

# 使用render_template()方法重定向到templates文件夹下查找get.html文件

return render_template('get.html')

# 配置路由,当请求post.html时交由post_html()处理

@app.route('/post.html')

def post_html():

# 使用render_template()方法重定向到templates文件夹下查找post.html文件

return render_template('post.html')

# 配置路由,当请求deal_request时交由deal_request()处理

# 默认处理get请求,我们通过methods参数指明也处理post请求

# 当然还可以直接指定methods = ['POST']只处理post请求, 这样下面就不需要if了

@app.route('/deal_request', methods = ['GET', 'POST'])

def deal_request():

if request.method == "GET":

# get通过request.args.get("param_name","")形式获取参数值

get_q = request.args.get("q","")

return render_template("result.html", result=get_q)

elif request.method == "POST":

# post通过request.form["param_name"]形式获取参数值

post_q = request.form["q"]

return render_template("result.html", result=post_q)

if __name__ == '__main__':

# app.run(host, port, debug, options)

# 默认值:host=127.0.0.1, port=5000, debug=false

app.run()

3.3 查看运行效果

重新运行helloworld.py。

当前目录结构如下(.idea目录不用管):

ef09f5c78a502bac250ec18b0e245c28.png

get.html如下:

6bed991dc62c81d0e0ef7eeab6504c24.png

get查询结果如下:

e1889432a6da53d713d7a1f1054d9840.png

post.html如下:

f5833bbe2964fc796f6c75388de1f79a.png

post查询结果如下:

87088e0dec58e4338cdf278ffb9f1c6a.png

四、restful

所谓restful简单理解就是以json等格式(而非以前的表单格式)发起请求,及以json等格式(而非以前的html)进行响应。

等下我们通过curl模拟rest请求,然后使用jsonify实现rest响应。

4.1 服务端实现代码

# 导入Flask类

from flask import Flask, jsonify

from flask import render_template

from flask import request

# 实例化,可视为固定格式

app = Flask(__name__)

# route()方法用于设定路由;类似spring路由配置

#等价于在方法后写:app.add_url_rule('/', 'helloworld', hello_world)

@app.route('/helloworld')

def hello_world():

return 'Hello, World!'

# 配置路由,当请求get.html时交由get_html()处理

@app.route('/get.html')

def get_html():

# 使用render_template()方法重定向到templates文件夹下查找get.html文件

return render_template('get.html')

# 配置路由,当请求post.html时交由post_html()处理

@app.route('/post.html')

def post_html():

# 使用render_template()方法重定向到templates文件夹下查找post.html文件

return render_template('post.html')

# 配置路由,当请求deal_request时交由deal_request()处理

# 默认处理get请求,我们通过methods参数指明也处理post请求

# 当然还可以直接指定methods = ['POST']只处理post请求, 这样下面就不需要if了

@app.route('/deal_request', methods=['GET', 'POST'])

def deal_request():

if request.method == "GET":

# get通过request.args.get("param_name","")形式获取参数值

get_q = request.args.get("q","")

return render_template("result.html", result=get_q)

elif request.method == "POST":

# post通过request.form["param_name"]形式获取参数值

post_q = request.form["q"]

return render_template("result.html", result=post_q)

@app.route('/rest_test',methods=['POST'])

def hello_world1():

"""

通过request.json以字典格式获取post的内容

通过jsonify实现返回json格式

"""

post_param = request.json

result_dict = {

"result_code": 2000,

"post_param": post_param

}

return jsonify(result_dict)

if __name__ == '__main__':

# app.run(host, port, debug, options)

# 默认值:host=127.0.0.1, port=5000, debug=false

app.run()

4.2 请求模拟

curl -H "Content-Type:application/json" -X POST --data '{"username": "ls","password":"toor"}' http://127.0.0.1:5000/rest_test

4.3 效果截图

7354a3743c4f1d3709412ad3e43204d4.png

五、Flask与Django比较

5.1 Django配置复杂

如果对Django不是很了解,可以参看

仅从文章长度看就比这篇长很多,所以Django比Flask复杂(得多)是肯定的。更具体比较如下:

比较项

Django

Flask

复杂度比较

说明

项目创建

Django需要用命令创建项目

Flask直接编写文件就可运行

Django复杂

Django需要用命令创建项目是因为要创建出整个项目框架

路由

Django使用专门的urls.py文件

Flask直接使用@app.route()

Django笨重

Django类似Strut2的配置Flask类似Spring的配置,Flask感觉更好

get和post

request.GET['name']和request.POST["name"]

request.args.get("name","")和request.form["q"]

差不多

Flask格式上不统一

restful

使用django-resful框架

使用jsonify

差不多

Flask不需要单建一个app,更直观一些

数据库操作

django集成了对数据库的操作

Flask没集成对数据库的操作要另行直连或使用sqlalchemy

差不多

django复杂很大程度来源于对数据库的集成。

5.2 Flask和Django各自适合使用场景

我们经常会听说这样的一个近乎共识的观点:Django是Python最流行的Web框架但配置比较复杂,Flask是一个轻量级的框架配置比较简单如果项目比较小推荐使用Flask。

进一步来说,Flask的轻量来源其“暂时不用的功能都先不做处理”,Django复杂来源于其“可能用到的功能都先集成”;随着项目规模的扩大最终Django有的东西Flask也都需要有。

所以,如果平时你用python是东用一个库西用一个库,东写一个场景西写一个场景,而不是专门开发web,那么你适合使用Flask,因为这样你的学习成本低及以前的知识都能用上去。

本文主要讲解了Python3+Flask安装使用教程如果想查看更多关于Python3+Flask的知识文章请点击下面相关文章

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值