Python Flask实现蓝图Blueprint配置和模块渲染

 Python基础学习:

  • Pyhton 语法基础
  • Python 变量
  • Python控制流
  • Python 函数与类
  • Python Exception处理
  • Python 文件操作
  • Python 日期与时间
  • Python Socket的使用
  • Python 模块
  • Python 魔法方法与属性

Flask基础学习:

  • Python中如何选择Web开发框架?
  • Python Flask 入门开发
  • 如何使用virtualenv实现python环境的隔离?
  • Python中使用国内源头下载依赖
  • Python Flask 路由配置
  • Flask 使用Context上下文
  • Python Flask实现蓝图Blueprint配置和模块渲染 

蓝图(BluePrint)

蓝图(Blueprint)是Flask实现的应用模块化,通过模块化的方式分割视图,让应用的层次更加清晰,更加便于开发者开发和维护项目。通过蓝图,我们可以创建一组相同前缀的路由组合,可以用于分割应用不同的服务。如应用有两个服务:认证服务和用户服务,我们可以通过模块化分割服务,然后通过Flask注册不同前缀的蓝图。

创建main服务

先创建一个main服务,代码如下:

1、创建main.py文件

# main.py
# !/usr/bin/env python
# -*-coding:utf-8 -*-
from datetime import datetime
from flask import render_template,session,redirect,url_for,abort,request,Blueprint
main = Blueprint('main', __name__)



@main.route('/index')
def index(item_name="dashboard", **kwargs):
    return render_template('manager/index.html', item_name=item_name, kwargs=kwargs)


@main.route('/user/<username>')
def user(username):
    return render_template('user.html', user=user)

2、创建api.py文件

# !/usr/bin/env python
# -*-coding:utf-8 -*-
from flask import jsonify, request,make_response,Blueprint,Flask
from. import api


@api.route('/post/', methods=['POST'])
def post():
    json = request.json
    print(str(json))
    post1 = Post.from_json(json)
    db.session.add(post1)
    db.session.commit()
    return jsonify({
        "status": 1,
        "response": u"提交成功"
    })

3、注册Blueprint

# !/usr/bin/env python
# -*-coding:utf-8 -*-
from flask import Flask,render_template,Response
from flask_cors import CORS

def create_app(config_name):
    app = Flask(__name__)
     # 注册main服务
    from .main import main as main_blueprint
    app.register_blueprint(main_blueprint, url_prefix='/manager')
    # 注册api服务
    from app.api import api as api_blueprint
    CORS(api_blueprint, supports_credentials=True)
    app.register_blueprint(api_blueprint, url_prefix='/api/v1.0')
    return app

 模块渲染(Template)

使用Flask可以直接在路由中返回Html文档,但处理起来比较麻烦。因此,Flask框架默认支持Jinja2末班引擎,可通过flask提供的内置方法render_template直接进行渲染,我们只需要提供html的相对路径即可,flask中默认模板目录为templates

如下通过一个示例看下flask中的模板渲染如何使用:

from flask import render_template,Flask

app = Flask(__name__)

@app.route('/hello/')
@app.route('/hello/<name>')
def hello(name=None):
    return render_template('base.html', name=name)

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

Jinja2 模板引擎

Jinja2 是一个现代的,设计者友好的,仿照 Django 模板的 Python 模板语言。 它速度快,被广泛使用,并且提供了可选的沙箱模板执行环境保证安全:4

<title>{% block title %}{% endblock %}</title>
<ul>
{% for user in users %}
  <li><a href="{{ user.url }}">{{ user.username }}</a></li>
{% endfor %}
</ul>

变量使用

Flask可以通过Jinja2模板将Python中的变量传递到html模板中。如下通过py和html中来了解如何使用:

// demo.py
from flask import Flask, render_template
 
 
app = Flask(__name__)
 
 
@app.route('/args')
def temp_jinja2():
    data = {
        'Python': '编程语言',
        'Flask': 'Web 框架',
        'Jinja2': '模板引擎',
        'HTML': '前端语言'
    }
    return render_template('route_two.html', data=data)
 
 
if __name__ == '__main__':
    app.run(debug=True)

如上,通过render_template传递jinja2参数。html使用变量如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Jinja2 Args</title>
</head>
<body>
<h2 style="color: red">获取 data 中的数据:</h2>
<p style="color: blue"> {{ data['Python'] }} </p>
<p style="color: blue"> {{ data['Flask'] }} </p>
<p style="color: blue"> {{ data.Jinja2 }} </p>
<p style="color: blue"> {{ data.HTML }} </p>
<br/>
{% if data %}
    {{ data.keys() }}
{% else %}
    <p style="color: blue"> Hello Jinja2 ! </p>
{% endif %}
<br/>
<br/>
{% for key in data.keys() %}
    <div>
        <p style="color: rebeccapurple"> {{ key }} : {{ data[key] }} </p>
    </div>
{% endfor %}
</body>
</html>

过滤器

Flask中模板过滤器的使用是通过管道符(|)分割,也 可以用圆括号传递可选参数。多个过滤器可以链式调用,前一个过滤器的输出会被作为 后一个过滤器的输入。如 {{ name|striptags|title }} 会移除 name 中的所有 HTML 标签并且改写 为标题样式的大小写格式。其使用格式如下:

// 使用格式
{% 变量 | 过滤器名 %} 

// 示例
{# 关闭HTML自动转义 #}
<p>{{ '<em>name</em>' | safe }}</p> 

常见的内置过滤器:

  • abs(number):返回参数的绝对值。
  • attr(objname):获取对象的属性。 foo|attr(‘bar’) 像 foo[‘bar’] 一样工作,只是总是返回一个属性并且不查找项目。
  • batch(valuelinecountfill_with=None):批处理项目的过滤器。它的工作原理与 slice 非常相似,只是反过来。它返回具有给定项目数的列表列表。如果您提供第二个参数,则该参数用于填充缺失的项目。
  • capitalize(s):大写一个值。第一个字符将是大写的,所有其他字符都是小写的。
  • center(valuewidth=80):将给定宽度的字段中的值居中。
  • default(valuedefault_value=u”boolean=False):如果该值未定义,它将返回传递的默认值,否则返回值。
  • dictsort(valuecase_sensitive=Falseby=’key’):对 dict 和 yield (key, value) 对进行排序。
  • escape(s):将字符串 s 中的字符 &、 、 、 ‘ 和 ” 转换为 HTML 安全序列。如果您需要在 HTML 中显示可能包含此类字符的文本,请使用此选项。将返回值标记为标记字符串。
  • filesizeformat(valuebinary=False):将值格式化为“人类可读”的文件大小(即 13 kB、4.1 MB、102 字节等)。默认使用十进制前缀(Mega、Giga 等),如果第二个参数设置为 True,则使用二进制前缀(Mebi、Gibi)
  • first(seq):返回序列的第一项。
  • float(valuedefault=0.0):将值转换为浮点数。如果转换不起作用,它将返回 0.0。您可以使用第一个参数覆盖此默认值。
  • forceescape(value):强制 HTML 转义。这可能会使转义变量加倍。
  • format(value*args**kwargs):在对象上应用 python 字符串格式。
  • groupby(valueattribute):按公共属性对一系列对象进行分组。
  • indent(swidth=4indentfirst=False):返回传递的字符串的副本,每行缩进 4 个空格。第一行没有缩进。
  • int(valuedefault=0):将值转换为整数。如果转换不成功,它将返回 0。
  • join(valued=u”attribute=None):返回一个字符串,它是序列中字符串的串联。
  • last(seq):返回序列的最后一项。
  • length(object):返回序列或映射的项目数。
  • list(value):将值转换为列表。如果它是一个字符串,则返回的列表将是一个字符列表。
  • lower(s):将值转换为小写。
  • map():对一系列对象应用过滤器或查找属性。这在处理对象列表时很有用,但您实际上只对它的某个值感兴趣。
  • pprint(valueverbose=False):漂亮地打印一个变量。对调试很有用。
  • random(seq):从序列中返回一个随机项。
  • reject():通过对对象或属性应用测试并拒绝测试成功的对象来过滤一系列对象。
  • rejectattr():通过对对象或属性应用测试并拒绝测试成功的对象来过滤一系列对象。
  • replace(soldnewcount=None):返回值的副本,所有出现的子字符串都替换为新的子字符串。
  • reverse(value):反转对象或返回一个迭代器,以相反的方式迭代它。
  • round(valueprecision=0method=’common’):将数字四舍五入到给定的精度。
  • safe(value):将该值标记为安全的,这意味着在启用了自动转义的环境中,该变量将不会被转义。
  • select():通过对对象或属性应用测试并仅选择测试成功的对象来过滤一系列对象。
  • selectattr():通过对对象或属性应用测试并仅选择测试成功的对象来过滤一系列对象。
  • slice(valueslicesfill_with=None):切片迭代器并返回包含这些项目的列表列表。
  • sort(valuereverse=Falsecase_sensitive=Falseattribute=None):对可迭代对象进行排序。默认情况下它按升序排序,如果您将它作为第一个参数传递 true 它将反转排序。
  • string(object):如果还没有,请创建一个字符串 unicode。这样标记字符串就不会转换回 unicode。
  • striptags(value):去除 SGML/XML 标签并将相邻的空格替换为一个空格。
  • sum(iterableattribute=Nonestart=0):返回数字序列加上参数“start”的值(默认为 0)的总和。当序列为空时,它返回开始。
  • title(s):返回值的标题版本。 IE。单词将以大写字母开头,所有其余字符均为小写字母。
  • trim(value):去除前导和尾随空白。
  • truncate(slength=255killwords=Falseend=’…’):返回字符串的截断副本。长度由第一个参数指定,默认为 255。
  • upper(s):将值转换为大写。
  • urlencode(value):用于 URL 的转义字符串(使用 UTF-8 编码)。它接受字典和常规字符串以及成对的可迭代对象。
  • urlize(valuetrim_url_limit=Nonenofollow=False):将纯文本的 URL 转换为可点击的链接。
  • wordcount(s):计算该字符串中的单词。
  • wordwrap(swidth=79break_long_words=Truewrapstring=None):返回传递给过滤器的字符串副本,在 79 个字符后换行。
  • xmlattr(dautospace=True):根据字典中的项目创建 SGML/XML 属性字符串。

示例代码

视图函数:

from flask import Flask, render_template

# todo 初始化Flask项目的服务
app = Flask(__name__)

student = {'name': 'kobe', 'age': 14, 'gender': '男'}

@app.route('/str')
def test1():
    return render_template('04-字符串的过滤器.html',**student)  #为了方便在模板中使用,可以把字典打伞


if __name__ == '__main__':
    # 0.0.0.0:代表当前的系统的所有的ip地址,
    # 设置端口为8080,
    # flask的debug模式:把错误的信息显示到页面中
    app.run(host='0.0.0.0', port=8080, debug=True)

模板文件:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>字符串的过滤器</title>
</head>
<body>

{# 当变量数据没有传入数据的时候,可以给变量设置默认值 #}
<p>{{ name | default('自律') }}</p>
<P>{{ name1 | default('自爱') }}</P>

{# 单词首字母大写 #}
<p>{{ 'hello world' | capitalize }}</p> 

{# 单词全小写 #}
<p>{{ 'XML' | lower }}</p> 

{# 去除字符串前后的空白字符 #}
<p>{{ ' hello ' | trim }}</p> 

{# 字符串反转,返回"olleh" #}
<p>{{ 'hello' | reverse }}</p> 

{# 格式化输出,返回"Number is 99" #}
<p>{{ '%s is %d' | format("Number", 99) }}</p> 

{# 关闭HTML自动转义 #}
<p>{{ '<em>name</em>' | safe }}</p> 

{% autoescape false %}{# HTML转义,即使autoescape关了也转义,可以缩写为e #}
<p>{{ '<em>name</em>' | escape }}</p>
{% endautoescape %}
</body>
</html>

 静态文件配置

Flask框架默认静态文件的目录为根目录下的static目录,默认模板文件目录为templates,或者也可以通过Flask来设置静态文件目录、模板目录、以及静态访问前缀。Flask支持的设置参数如下:

    def __init__(
        self,
        import_name: str,  
        static_url_path: t.Optional[str] = None,
        static_folder: t.Optional[t.Union[str, os.PathLike]] = "static",
        static_host: t.Optional[str] = None, 
        host_matching: bool = False,
        subdomain_matching: bool = False,
        template_folder: t.Optional[str] = "templates",
        instance_path: t.Optional[str] = None,
        instance_relative_config: bool = False,
        root_path: t.Optional[str] = None,
    )

如下,我们可以通过一个示例来看一下如何设置:

from flask import Flask

app = Flask(import_name=__name__,
            static_url_path='/',
            static_folder='static',
            template_folder='templates')

如下,通过一个示例来看下如何配置静态文件。

创建main.py

from flask import Flask, render_template


app = Flask(import_name=__name__, static_url_path='/',
            static_folder='static', template_folder='templates')


# 添加html访问路由
@app.route('/')
def blog():
    return render_template('index.html')


if __name__ == "__main__":
    app.run()  # 默认设置host:0.0.0.0 port:5000

创建静态文件和模板文件

如下所示,在模板中我们可以通过url_for来访问获取静态文件,格式如下:

url_for(<static-folder>,<static-relative-path) # 社会静态目录和相对静态目录的静态文件地址

访问结果

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/686794.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

SQLserver通过CLR调用TCP接口

一、SQLserver启用CLR 查看是否开启CRL&#xff0c;如果run_value1&#xff0c;则表示开启 EXEC sp_configure clr enabled; GO RECONFIGURE; GO如果未启用&#xff0c;则执行如下命令启用CLR sp_configure clr enabled, 1; GO RECONFIGURE; GO二、创建 CLR 程序集 创建新项…

【算法】深入浅出爬山算法:原理、实现与应用

人不走空 &#x1f308;个人主页&#xff1a;人不走空 &#x1f496;系列专栏&#xff1a;算法专题 ⏰诗词歌赋&#xff1a;斯是陋室&#xff0c;惟吾德馨 目录 &#x1f308;个人主页&#xff1a;人不走空 &#x1f496;系列专栏&#xff1a;算法专题 ⏰诗词歌…

简单聊下办公白环境

在当今信息化时代&#xff0c;办公环境对于工作效率和员工满意度有着至关重要的影响。而白名单作为一种网络安全策略&#xff0c;其是否适合办公环境&#xff0c;成为了许多企业和组织需要思考的问题。本文将从白名单的定义、特点及其在办公环境中的应用等方面&#xff0c;探讨…

Excel 生成所在月份的每一天列表

Excel 的 A2 格是日期 A1Fecha201/03/24 需要生成该日期所在月份的每一天的列表 A1WholeMonth201/03/24302/03/24403/03/24504/03/24605/03/24706/03/24807/03/24908/03/241009/03/241110/03/241211/03/241312/03/241413/03/241514/03/241615/03/241716/03/241817/03/241918…

操作系统入门系列-MIT6.828(操作系统工程)学习笔记(三)---- xv6初探与实验一(Lab: Xv6 and Unix utilities)

系列文章目录 操作系统入门系列-MIT6.S081&#xff08;操作系统&#xff09;学习笔记&#xff08;一&#xff09;---- 操作系统介绍与接口示例 操作系统入门系列-MIT6.828&#xff08;操作系统工程&#xff09;学习笔记&#xff08;二&#xff09;----课程实验环境搭建&#x…

Git - 详解 创建一个新仓库 / 推送现有文件夹 / 推送现有的 Git 仓库 到私有Gitlab

文章目录 【推送现有文件夹】详细步骤指令说明Git 全局设置设置Git全局用户名设置Git全局电子邮件地址 推送现有文件夹1. 进入现有文件夹2. 初始化Git仓库并设置初始分支为main3. 添加远程仓库4. 添加所有文件到暂存区5. 提交更改6. 推送代码到远程仓库并设置上游分支 创建一个…

FISCO BCOS助力郑州数据交易中心“碳账户”小程序上线

近年来&#xff0c;科技和数字化成为推进可持续绿色发展的关键词。在第53个世界环境日来临之际&#xff0c;由FISCO BCOS支持建设的郑州数据交易中心双碳数据服务专区迎来了新进展&#xff01;近日&#xff0c;专区正式以"碳账户"小程序对外提供多种形式的碳数据服务…

如何在MySQL中创建不同的索引和用途?

目录 1 基本的 CREATE INDEX 语法 2 创建单列索引 3 创建多列索引 4 创建唯一索引 5 创建全文索引 6 在表创建时添加索引 7 使用 ALTER TABLE 添加索引 8 删除索引 9 索引管理的最佳实践 10 示例 在 MySQL 中&#xff0c;索引&#xff08;index&#xff09;是一种用于…

人形机器人位置控制新方案!法国洛林大学诞生多触点全身力控制控制器

对人形机器人的接触力间接控制&#xff0c;以增强机器人在复杂环境中的感知与交互能力。 这是来自法国洛林大学的新研究&#xff0c;研究团队研发了一款多触点全身力控制控制器。 在针对全尺寸人形机器人Talos的实验中&#xff0c;通过应用该控制器的新方法&#xff0c;成功验…

香橙派Orange AI Pro / 华为昇腾310芯片 部署自己训练的yolov8模型进行中国象棋识别

香橙派Orange AI Pro / 华为昇腾310芯片 部署自己训练的yolov8模型进行中国象棋识别 一、香橙派简介1.1、香橙派 AI Pro 硬件资源介绍1.2、华为昇腾310&#xff08;Ascend310&#xff09; 简介1.3、 昇腾310AI能力和CANN 简介昇腾310 NPU简介 二、远程环境配置2.1、ssh2.2、vnc…

Day23 自定义对话框服务

​本章节实现了,自定义对话框服务的功能 当现有的对话框服务无法满足特定需求时,我们可以采用自定义对话框的解决方案,以更好地满足一些特殊需求。 一.自定义对话框主机服务步骤 在Models 文件夹中,再建立一个 IDialogHostService 接口类,继承自 IDialogService 对话框服…

CrawlSpace爬虫部署框架介绍

CrawlSpace爬虫部署框架介绍 全新的爬虫部署框架&#xff0c;为了适应工作的爬虫部署的使用&#xff0c;需要自己开发一个在线编写爬虫及部署爬虫的框架&#xff0c;框架采用的是Django2.2bootstap依赖scrapyd开发的全新通用爬虫在线编辑部署及scrapy项目的部署框架。项目实现的…

SCT2613TVBR——4.5V-60V Vin,1A,高效降压DCDC转换器

•宽输入范围&#xff1a;4.5V-60V •高达1A的连续输出电流 •0.765V2.5%反馈参考电压 •集成500mΩ高压侧MOSFET •低静态电流为80uA •轻负载下的脉冲跳过模式&#xff08;PSM&#xff09; •最小接通时间80ns •内置6ms软启动时间 •内部补偿 •开关频率为480KHz •可编程输…

IP质量不够好,可以使用高质量的代理IP吗?

在当今互联网时代&#xff0c;IP代理是一个不可或缺的工具&#xff0c;但许多人可能对它的原理和应用感到困惑。IP代理涉及IP地址的使用和切换&#xff0c;旨在提供更好的隐私保护和访问控制。本文将介绍IP代理的工作原理以及为什么选择高质量的代理IP。 一、IP代理的基本原理…

计网复习资料

一、选择题&#xff08;每题2分&#xff0c;共40分&#xff09; 1. Internet 网络本质上属于&#xff08; &#xff09;网络。 A.电路交换 B.报文交换 C.分组交换 D.虚电路 2.在 OSI 参考模型中,自下而上第一个提供端到端服务的是( )。 A.数据链路层 B.传输…

TPM仿真环境搭建

文章目录 背景及注意事项一、CMake二、m4三、GNU MP Library四、TPM_Emulator五、TSS协议栈&#xff08;trousers-0.3.14.tar.gz&#xff09;六、 tpm-tools七、查看是否安装成功八、测试 TPM环境&#xff08;需要开三个终端分别运行&#xff09;8.1 启动TPM &#xff08;第一个…

cad导入su线条不在一个平面怎么办?

解决CAD导入sketchup线条不是共面问题&#xff0c;需要考虑到各个步骤如下&#xff1a; 1&#xff09;检查CAD文件。首先要检查CAD文件&#xff0c;确保线条是连接在一起的&#xff0c;并且看看有没有多余的线&#xff0c;以及是否有子线段没有合并&#xff0c;如果有会导致导入…

常用的Linux命令,linux下文件的读、写、打开、关闭append用法

vim demoq.c打开写的.c文件 内容为 按a可以编辑页面代码。按ESC退出编辑然后按shift&#xff1a;wq保存文件并退出 Linux 系统中采用三位十进制数表示权限&#xff0c;如0755&#xff0c; 0644.7 124(可读、可写、可执行&#xff09; 5 14(可读、不可写、可执行&#xff09; …

CAD 文件(DXF / DWG)转换为(DXF / PDF / PNG / SVG)

方法一Github 这个是ezdxf出品的&#xff0c;可以使用命令行的方式进行转换 ezdxf draw -o file.<png|svg|pdf> <file.dxf>也可以自己改动代码 examples/addons/drawing/pdf_export.py 但是直接运行会有误&#xff0c;以下是我改动后的代码&#xff1a; from ez…

静态 VxLAN 浅析及配置示例(头端复制)

一、概念&#xff1a; VxLAN&#xff1a;Visual eXtensible Local Area Network 虚拟扩展本地局域网&#xff0c;一种隧道技术&#xff0c;能在三层网络的基础上建立二层以太网网络隧道&#xff0c;从而实现跨地域的二层互连&#xff0c;VxLAN端口&#xff1a;4789EVPN&#x…