Python Flask Web 项目实战

一、基础

1,首先是虚拟环境的配置

pip install virtualenv -i https://pypi.doubanio.com/simple  # 豆瓣源安装虚拟环境
mkdir falsk-venv
cd falsk-venv
virtualenv venv  # 在当前目录下床架一个目录,表示虚拟环境的目录名为venv,包含了Python可执行文件,以及pip库的一个备份

当然如果本机存在多个版本的Python,可以选择一个Python,可以选择一个Python解释器,在指定之前,必须将flask-venv目录下整个文件夹都删掉再使用

virtualenv -p C:Python27\python.exe venv  # -p 用来指定Python解释器程序的路径

那如何激活使用虚拟环境呢?

在cmd里面输入

dir
activate  # 激活虚拟环境
deactivate  # 退出虚拟环境
rmvirtualenv flask-venv  # 删除虚拟环境

2,Flask 快速上手

使用pycharm来创建

from flask import Flask

app = Flask(__name__)

@app.route(‘/‘)
def hello_world():
    return ‘Hello World!‘

if __name__ == ‘__main__‘:
    app.run()

有人会问啊,为什么非要加这个

if __name__ == ‘__main__‘:

其实原因是在python中,所有没有缩进的代码都会被执行,__name__是Python的内建函数,指的是当前模块的名称,,每个模块都有这个属性,但__name__是可以变化的,如果某个模块直接被运行那么__name__ = ‘__main__‘, 条件为真,但是当模块被导入的时候就为假,也就是app.run()不会被执行。

和Django不同的是flask的路由是以装饰器的形式加载所需要执行视图函数的上方

调试:

django的开启调试是在settings中的DEBUG=True,而flask简单很多,在app.run()中加入debug=True即可

from flask import Flask

app = Flask(__name__)

@app.route(‘/‘)
def hello_world():
    return ‘Hello World!‘

if __name__ == ‘__main__‘:
    app.run(debug=True)  # 开启调试

flask开启调试好处是什么呢?

1,遇到程序有bug,会在控制台输出具体的错误信息,否则只会报笼统的应用服务器错误。

2,自动重启

当然app.run中可以加的参数还有很多,比如设定host,port

另外说一句:默认的port就是5000

from flask import Flask

app = Flask(__name__)

@app.route(‘/‘)
def hello_world():
    return ‘Hello World!‘

if __name__ == ‘__main__‘:
    app.run(debug=True, host=‘0.0.0.0‘, port=8000)

二、URL传递参数

Flask传递参数的语法是‘/参数/‘

注意点:①参数需要放在一对<>②视图函数中需要设置与URL中相同的参数名

from flask import Flask

app = Flask(__name__)

@app.route(‘/user/<name>‘)
def hello_world(name):
    return f‘Hello World!{name}‘

if __name__ == ‘__main__‘:
    app.run(debug=True, host=‘0.0.0.0‘, port=8000)

像这个就是没有指定数据的类型的,那么默认的就是string

from flask import Flask

app = Flask(__name__)

@app.route(‘/user/<int:id>‘)
def hello_world(id):
    return f‘Hello World!{id}‘

if __name__ == ‘__main__‘:
    app.run(debug=True, host=‘0.0.0.0‘, port=8000)

像这样就是指定接收的参数类型为int类型,传递参数str或者float都是不行的

三、URL的反转

我们知道Django的URL反转模板语言中使用的是这样{% url ‘name’ %} 通过别名的方式,视图函数中是这样

from django.shortcuts import reverse
reverse(‘article:article_detail‘, kwargs={‘id‘: article_id, ‘slug‘: slug})

但是在flask中,URL的反转却很有意思直接使用url_for

from flask import Flask, url_for

app = Flask(__name__)

@app.route(‘/user‘)
def hello_world(id):
    reverse_path = url_for(‘hello_world‘)
    return f‘Hello World!{reverse_path}‘

if __name__ == ‘__main__‘:
    app.run(debug=True, host=‘0.0.0.0‘, port=8000)

使用URL的反转,使用的是

from flask import url_for

最简单的做法即使以视图函数的名称作为参数,就像上面例子得到的就是/user

三、模板引擎jinja2

因为jinja2和Django模板引擎基本一样,所以基础的就不讲了,直接开干

比方说我们随便在templates目录下新建一个html文件user.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<div>{{ name }}</div>

</body>
</html>

app.py文件代码如下:

from flask import Flask, render_template

app = Flask(__name__)

@app.route(‘/user‘)
def hello_world():
    name = ‘先生‘
    return render_template(‘user.html‘, name=name)

if __name__ == ‘__main__‘:
    app.run(debug=True, host=‘0.0.0.0‘, port=8000)

和Django的不同的是:Django使用render(request, ‘模板‘)来进行返回

Flask通过render_template()函数来实现模板的渲染。要使用jinjia2模板就是必须用

from flask import render_template

当然参数量过多的时候**locals()

from flask import Flask, render_template

app = Flask(__name__)

@app.route(‘/user‘)
def hello_world():
    name = ‘先生‘
    return render_template(‘user.html‘, **locals())

if __name__ == ‘__main__‘:
    app.run(debug=True, host=‘0.0.0.0‘, port=8000)

而Django不要加**

上面的都是太简单了,整点有难度的,举个栗子,自定义过滤器(本质上过滤器就是转换函数)

我们都知道django的过滤器需要在各自的app下新建一个templatetags,然后在模板中导入缩写的py文件

那么Flask怎么做的呢?

通过调用add_template_filter方法来实现。该方法第一个参数是函数名,第二个参数是自定义过滤器的名称。

user.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<div>{{ name | index_class }}</div>

</body>
</html>

app.py

from flask import Flask, render_template

app = Flask(__name__)

@app.route(‘/user‘)
def hello_world():
    name = ‘先生‘
    return render_template(‘user.html‘, **locals())

def do_index_class(index):  # 定义函数
    return index + ‘牛逼****‘

app.add_template_filter(do_index_class, ‘index_class‘)

if __name__ == ‘__main__‘:
    app.run(debug=True, host=‘0.0.0.0‘, port=8000)

宏的定义及使用:

Jinja 2中的宏功能类似Python中的函数,可以传参,但是不能有返回值。我们可以将一些经常用到的代码片段放在宏中,然后把一些不固定的值抽取出来作为一个变量。

宏的声明:

<!--定义宏-->
    {% macro input (name, type=‘text‘, value=‘‘) -%}
        <input type="{{ type }}" name="{{ name }}" value="{{ value|e }}">
    {%- endmacro  %}

上方的代码定义了一个宏,定义宏要加macro,结束要加上endmacro标志。宏的名称时input

他们有三个参数,分别是name、type、value。后两个参数有默认值。我们可以试用表达式来调用这个宏

{{ input(‘username‘) }}
{{ input(‘password‘, type=‘password‘) }}

看一个完整的实例:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<div>{{ name | index_class }}</div>
<div>
    <!--定义宏-->
    {% macro input (name, type=‘text‘, value=‘‘) -%}
        <input type="{{ type }}" name="{{ name }}" value="{{ value|e }}">
    {%- endmacro  %}

<p>用户名:{{ input(‘username‘) }}</p>
<p>密码:{{ input(‘password‘, type=‘password‘) }}</p>
<p>登录:{{ input(‘submit‘, type=‘submit‘, value=‘登录‘) }}</p>

</div>

</body>
</html>

宏的导入:

一个宏可以被不同的模板使用,因此我们想到了一个东西,抽取为公共模块,在需要使用的时候导入即可

导入的方法呢也和Python类似,import嘛

因为我们在上面已经写了一个宏了

那我们就导入

方式1:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
{% import ‘user.html‘ as user %}
<p>用户名:{{ user.input(‘username‘) }}</p>
<p>密码:{{ user.input(‘password‘, type=‘password‘) }}</p>
<p>登录:{{ user.input(‘submit‘, type=‘submit‘, value=‘登录‘) }}</p>
</body>
</html>

方式二:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
{% from ‘user.html‘ import input %}
<p>用户名:{{ input(‘username‘) }}</p>
<p>密码:{{ input(‘password‘, type=‘password‘) }}</p>
<p>登录:{{ input(‘submit‘, type=‘submit‘, value=‘登录‘) }}</p>
</body>
</html>

效果是完全一样的

include的使用:

和django的include类似:

宏文件可以引用其他宏,可以使用include语句可以把一个模板引入到另一个模板中,类似于把一个模板的代码复制到另外一个模板的指定位置。

footer.hrml

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<div class="footer">这是网页尾部</div>

</body>
</html>

header.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<div class="header">这是网页头部</div>

</body>
</html>

index.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        .header {
            width: 100%;
            height: 40px;
            margin: 20px 20px;
        }
        .footer {
            width: 100%;
            height: 40px;
            margin: 20px 20px;
        }
        .content {
            width: 100%;
            height: 40px;
            margin: 20px 20px;
        }
    </style>
</head>
<body>
{% from ‘user.html‘ import input %}
<p>用户名:{{ input(‘username‘) }}</p>
<p>密码:{{ input(‘password‘, type=‘password‘) }}</p>
<p>登录:{{ input(‘submit‘, type=‘submit‘, value=‘登录‘) }}</p>
{% include "header.html" %}
<div class="content">这是网页内容</div>
{% include "footer.html" %}
</body>
</html>

页面效果:

set 和with语句的使用:

set语句是在模板中定义变量并赋予值,在整个模板范围都有效

with关键字是在定义变量并赋值的同事,限制with定义变量的作用范围

{% set a = ‘上山打老虎‘ %}
{% set b = [‘上山打老虎‘, (‘天青色等烟雨‘, ‘而我在等你‘)] %}
{{ a }}
{{ b }}
{% with bat = 99 %}
    {{ bat }}
{% endwith %}

静态文件的加载:

<script type="text/javascript" src="static/js/jquery-3.3.1/jquery-3.3.1.js"></script>
<script src="{{ url_for(‘static‘, filename=‘js/jquery-3.3.1/jquery-3.3.1.js‘) }}"></script>
<script src="{{ url_for(‘static‘, filename=‘images/dog.jpg‘) }}"></script>
<link rel="stylesheet" href="{{ url_for(‘static‘, filename=‘css/dog.css‘) }}">

推荐使用{{url_for}}的方法

模板的继承:

和Django一样,在需要继承的子模板中extends即可

父模板user.html

{% block baby %}
{% endblock %}

子模版

{% extends ‘user.html‘ %}
 {% block baby %}
     {{ super() }}
{% endblock %}

注意:如果想在一个block中调用其他的block代码可以通过{{self.其他block名称()}}实现

{% self.baby() %}

四、Flask视图高级技术

原文地址:https://www.cnblogs.com/zhoulixiansen/p/11650967.html

时间: 2024-10-08 20:00:12

Python Flask Web 项目实战的相关文章

python数据分析--KaggleTitanic项目实战

主要围绕Kaggle上的比赛题目: "给出泰坦尼克号上的乘客的信息, 预测乘客是否幸存" 进行一个简单的数据分析 环境 win8, python3.7, jupyter notebook 正文 1. 项目背景 泰坦尼克号: 是当时世界上体积最庞大.内部设施最豪华的客运轮船, 于1909年3月31日动工建造, 1912年4月2日完工试航. 于1912年4月10日, 在南安普敦港的海洋码头, 启程驶往纽约, 开始了它的第一次, 也是最后一次的航行. 泰坦尼克号将乘客分为三个等级: 三等舱位

python django web项目的构建步骤(一)

Django 一个开放源代码的Web应用框架,由Python写成.采用了MVC的软件设计模式,即模型M,视图V和控制器C.它最初是被开发来用于管理劳伦斯出版集团旗下的一些以新闻内容为主的网站的.并于2005年7月在BSD许可证下发布. 1.安装好python django(这步略过,安装过程自行完成,网上安装步骤很多),安装的版本不同而生成的文件目录也不同,这里用的是1.6.5的版本的django: [[email protected] ~]# django-admin.py --version

python django web项目的构建步骤(二)

视图的实现: 视图是一个简单的 Python 方法,它接受一个请求对象,负责实现: 任何业务逻辑(直接或间接) 上下文字典,它包含模板数据 使用一个上下文来表示模板 响应对象,它将所表示的结果返回到这个框架中 在 Django 中,当一个 URL 被请求时,所调用的 Python 方法称为一个视图(view),这个视图所加载并呈现的页面称为模板(template).由于这个原因,Django 小组将 Django 称为一个 MVT(model-view-template)框架.另一方面,Turb

CP2044-深入Java Web项目实战精讲(2套实战项目)

随笔背景:在很多时候,很多入门不久的朋友都会问我:我是从其他语言转到程序开发的,有没有一些基础性的资料给我们学习学习呢,你的框架感觉一下太大了,希望有个循序渐进的教程或者视频来学习就好了.对于学习有困难不知道如何提升自己可以加扣:1225462853进行交流得到帮助,获取学习资料. 下载地址:http://pan.baidu.com/s/1eQcrfMA 课程目标:1.把握Shiro的工作原理 2.把握Shiro的体系机构和运行流程 3.把握Shiro的核心组件和使用 4.实现Shiro和JSP

Python Flask web入门例子

安装pip -安装完python,需要手动设置pip环境变量,找到python安装目录的Scripts文件夹中就是根目录,比如C:\Python27\Scripts.设置完环境变量即可安装第三方模块了,安装时为了提高速度可以使用阿里镜像,方法如下 打开目录:C:\Users\xxx\AppData\Roaming,xxx是windows用户名 在该目录中新建目录pop,在pop目录中在新建pip.ini,其内容填入下面内容即可 [global] index-url=http://mirrors.

【Python + Flask + Web录音 + baidu-aip + 图灵机器人 = 人机对话】 &#106514;

原文: http://blog.gqylpy.com/gqy/351 安装baidu-aip:pip install baidu-aip 百度云网址:https://login.bce.baidu.com 百度语音合成文档:https://ai.baidu.com/docs#/TTS-Online-Python-SDK/top 百度语音识别文档:https://ai.baidu.com/docs#/ASR-Online-Python-SDK/top 百度自然语言处理基础技术文档:https://

Java Web项目实战记录(数据库表设计)

又是忙到这个点 虽然累,但是看着自己的项目在一点一点的成长,心里满满的成就感>_< 今天上了一下午的cep(职场社交礼仪规划课程),是不是职场就像cep老师说的那么的勾心斗角呢? 所以今天并没有做了多少东西,数据库的文档已经出来了,但是不是太详细,表之间的关系并没有说的太清(数据库的设计我并没有参与) 以下是数据库的文档: --------------------------------------------------------------------------------------

python flask web框架简明教程

http://www.itmin.cn/archives/category/flask

Flask Web开发实战(入门、进阶与原理解析)

URL重定向 错误响应 > 如果你想手动返回错误响应,可以使用Flask提供的abort()函数. XML 原文地址:https://www.cnblogs.com/plusUltra/p/10551555.html