python的“ hello world !”比较简单,python2.7下直接print, python3.x中print成为了内置函数,需要加()。
完成了Flask开发环境的搭建之后,这一节主要是学习使用Flask写出"hello world !"
Flask简介
Flask 是一个用于 Python 的微型网络开发框架,依赖两个外部库: Jinja2 模板引擎和 Werkzeug WSGI 套件。
Jinja我大致看过一些,不是很难理解,但是werkzeug涉及东西比较底层,我还暂时没看懂。之后慢慢理解。
从目前我理解的角度来看,写一个简单Flask应用,除了主文件hello.py之外,还需要模板文件夹和静态文件夹。
程序基本结构
程序初始化
Flask程序都必须创建一个程序示例,通常使用如下代码来创建:
from flask import Flask
app = Flask(__name__)
Flask 类的构造函数只有一个必须指定的参数,即程序主模块或包的名字。在大多数程序中, Python 的 name 变量就是所需的值。
路由和路由视图
刚开始看到这个“路由”的时候还是比较迷惑的,毕竟年轻的我想到了“路由器”。
这里的“路由”指的是处理URL和函数之间关系程序,程序在运行的时候需要知道不同的URL对应处理哪一段代码,所以通过路由来保存每个URL到python函数的映射关系。
通俗的来讲,就是你在浏览器的地址栏输入URL之后,浏览器把这个请求发送给Web服务器,Web服务器接着把这个请求发送给程序,程序根据路由来判断你输入这个URL之后它应该执行哪一段代码。
下面是一个简单的例子:
@app.route("/")
def index():
return "Hello World!"
"/"通常代表根目录,即根地址时处理index()函数。
如果部署程序的服务器域名为 www.123.com,在浏览器中访问 http://www.123.com 后, 会触发服务器执行 index() 函数。这个函数的返回值称为响应,是客户端接收到的内容。如果客户端是 Web 浏览器, 响应就是显示给用户查看的文档。
路由对应的函数成为视图函数,比如在以上的例子中,index()函数就是视图函数。视图函数的返回值可以是简单的html代码片段,也可以是表单等。
以上的例子中路由值为“/”是一个固定的值,但是现在大部分网站的路由值都是根据用户的输入值可变的,我称为动态路由(不知道对不对)。
举个栗子。
@app.route("user/<name>")
def user(name):
return "Hello, %s" % name
动态路由的动态部分用<>标识,调用视图函数时, Flask 会将动态部分作为参数传入函数。
在上面的例子中,s%在python中用于格式化字符串,没怎么接触过,刚好研究了下顺便。
name = "TOM"
print “hello %s” % name
在第二行中print了一个格式化字符串,把name变量的内容替换到%s处。打印出来就是:
Hello Tom
服务器启动
完成了以上的初始化和路由以及视图函数的编写,还需要启动服务器,使用如下代码来启动:
if __name__ == "__main__":
app.run(debug = True)
name==' main' 是 Python 的惯常用法,在这里确保直接执行这个脚本时才启动开发Web 服务器。 如果这个脚本由其他脚本引入,程序假定父级脚本会启动不同的服务器,因此不会执行 app.run()。
有一些选项参数可被 app.run() 函数接受用于设置 Web 服务器的操作模式。在开发过程中启用调试模式会带来一些便利, 比如说激活调试器和重载程序。要想启用调试模式, 我们可以把 debug 参数设为 True。
综上,写一个简单的包含静态路由和动态路由的程序。实现“hello world”以及“hello <user>”的功能。
from flask import Flask
app = Flask(__name__)
@app.route("/")
def index():
return "Hello World"
@app.route("/user/<name>")
def user(name):
return "Hello %s" % name
if __name__ == "__main__":
app.run(debug = True)
python程序在运行之前,必须激活虚拟环境(因为我们之前设置了虚拟环境),Windows下面,首先需要激活虚拟环境,打开CMD,切换到虚拟环境venv当前目录。
venv\Scripts\activate
然后切换到hello.py所在目录,使用下述命令启动程序:
python hello.py