我们都知道学习了Flask的时候它里面的参数是有很多种的参数  都是需要相互进行调用传递的  今天就简要分析一些常见的参数

首先导入Flask之后看 源码

from flask import Flask

首先看到我们的Flask类继承了一个 _PackageBoundObject类 这个类是有大用处的,下面我们在进行分解

首先找到Flask中的__init__中的 参数

def __init__(
self,
import_name, #默认参数必须传递
static_url_path=None,  # 静态文件的地址前缀,写的是什么在访问静态文件的时候就会加这个
static_folder='static', #静态文件所在文件夹的名字 默认是static 可以进行修改
     static_host=None,
host_matching=False,
subdomain_matching=False,
template_folder='templates',    # 模板所在的文件夹名字,虽然是默认的但是可以修改
    instance_path=None,
instance_relative_config=False,
root_path=None              # 当前执行文件所在目录地址
):

当我们执行return render_template 会将root_path和template_folder进行拼接

instance_pathinstance_relative_config是配合来用的:

这两个参数是用来找配置文件的,当用app.config.from_pyfile('settings.py')这种方式导入配置文件的时候会用到

instance_relative_config:默认为False,当设置为True时from_pyfile会从instance_path指定的地址下查找文件。

instance_path:指定 from_pyfile查询文件的路径,不设置时,默认寻找和app.run()的执行文件同级目录下的instance文件夹,如果配置了instance_path(注意需要是绝对路径),就会从指定的地址下里面的文件

instance_path 这是放置运行时更改的文件和配置文件的最佳位置,也就是我们的默认的配置文件更改之后就会 需要这个配置选项

app = Flask(__name__, instance_path='/path/to/instance/folder')

请注意给出的 一定 是绝对路径。

import_name这个参数只尤其重要的  因为很多的参数的获取都是由import_name来获取的 ,并且这个import_name就是代表我们的实例化传参的__name__

如果没有传递__name__或者import_name就会报错:

class Application(Flask):

    # 因为它的默认的是在templates但是我没修改了文件存放路径 也需要把寻找文件路径给修改,其中的static文件在正式开发中式不需要的  因为有其他方法可以直接找到

    def __init__(self,import_name,template_folder = None,root_path =None): #因为模板会自动默认的从templates下找 因为我没改变来的模板路径 所以我们要自定义路径
super(Application,self).__init__(import_name,template_folder=template_folder,root_path = root_path,static_folder=None) # __init__可以查看你所需要的源码
self.config.from_pyfile('config/base_setting.py')#导入配置文件 app = Application(__name__,template_folder = os.getcwd()+"/web/templates/",root_path=os.getcwd())

最开始Flask集成的 _PackageBoundObject类 是对我们的

        _PackageBoundObject.__init__(  # 调用自己的init然后接受参数
self,
import_name,
template_folder=template_folder,
root_path=root_path
)

从上面可以看出Flask 继承自_PackageBoundObject 类,在Flask 的init 魔法方法中调用了父类_PackageBoundObject init 魔法方法.

然后通过传递来的import_name来获取root_path

 def __init__(self, import_name, template_folder=None, root_path=None):
self.import_name = import_name
self.template_folder = template_folder if root_path is None:
root_path = get_root_path(self.import_name) # 获取root_path self.root_path = root_path
self._static_folder = None
self._static_url_path = None

flask 通过调用父类_PackageBoundObject 初始化方法设置import_name / template_folder / root_path 实例属性的值. root_path 属性的值是使用import_name 属性作为参数,调用get_root_path方法得到的.

通过这里可以更直观的看出 root_path 得到的是主模块所在的目录的绝对路径

也就是我们通过import_name然后得到的参数__name__ 来通过_PackageBoundObject 获取到当前文件的路径,这就是我们的实例化的时候为什么一定要__name__这是为了告诉其他的掉用文件我们的路径

Flask 参数简介的更多相关文章

  1. mqtt------ mosca服务器端参数简介

    一:服务器端 为什么使用mosca:mosca是基于node.js开发,上手难度相对较小,其次协议支持完整,除了不支持Qos 2,其它的基本都支持.持久化支持redis以及mongo.二次开发接口简单 ...

  2. Flask小总结+实例化Flask参数以及对app的配置

    Flask 小而精 三方组件全 稳定性相对较差 1.启动: from flask import Flask app = Flask(__name__) app.run("0.0.0.0&qu ...

  3. 【ABAP系列】SAP abap dialog screen屏幕参数简介

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[ABAP系列]SAP abap dialog ...

  4. Flask (一) 简介

    Flask简介 Flask是一个基于Python实现的Web开发‘微’框架 'MicroFramework' Django是一个重型框架 官方文档: http://flask.pocoo.org/do ...

  5. Flask 框架 简介

    一.Flask介绍 Flask是一个基于Werkzeug,Jinja 2 轻量级的web开发框架, 使用Python开发, 上手简单. 二.安装Flask 三.第一个Flask程序 1.编写app.p ...

  6. Flask参数解析、请求钩子

    转载请注明出处 https://www.cnblogs.com/chenxianpao/p/9949279.html  参数解析 Flask的参数解析主要用Request完成(from flask i ...

  7. HOG参数简介及Hog特征维数的计算(转)

    HOG构造函数 CV_WRAP HOGDescriptor() :winSize(64,128), blockSize(16,16), blockStride(8,8),      cellSize( ...

  8. VM参数简介

    http://www.cnblogs.com/yuzhaoxin/p/4083612.html block_dump Linux 内核里提供了一个 block_dump 参数用来把 block 读写( ...

  9. 【转载】va_list 可变参数 简介 va_copy vprintf

    [说明]本文转载自 smart 的文章 http://blog.sina.com.cn/s/blog_590be5290100qhxr.html  及百度百科 va_list是一个宏,由va_star ...

随机推荐

  1. chroot的用法

    chroot命令用来在指定的根目录下运行指令.chroot,即 change root directory (更改 root 目录).在 linux 系统中,系统默认的目录结构都是以/,即是以根 (r ...

  2. git工具,conflict冲突解决方法

    这篇文章需要对git具有一定的了解,并且知道如何安装git工具(其实就是上git官网下载个文件,安装) git这种版本控制工具有什么好处 第一个,方便可以多人协同开发同一个项目或系统 第二个,当你系统 ...

  3. glog功能介绍

    1.   概述       Google glog是一个基于程序级记录日志信息的c++库,编程使用方式与c++的stream操作类似,例:        LOG(INFO) << &quo ...

  4. elasticsearch(一):JAVA api操作

    1.创建一个mavan项目,项目的以来配置如下. <?xml version="1.0" encoding="UTF-8"?> <projec ...

  5. springMVC对于Controller返回值的可选类型

    2018-01-11 对于springMVC处理方法支持支持一系列的返回方式:  (1)ModelAndView (2)Model (3)ModelMap (4)Map (5)View (6)Stri ...

  6. 页面常见布局以及实现方法--flex

    页面布局是前端工程师的基本功之一,总结分析各种布局实现方法,可以让自己快速定位哪种方法实现功能,同时可以做到现最大程度的兼容. 一.水平居中 假设:最基本机构 .parent>.child 1. ...

  7. fiddler工作原理和设置代理问题

    1,什么是Fiddler Fiddler是一个http协议调试代理工具,它能够记录客户端和服务器之间的所有 HTTP请求,可以针对特定的HTTP请求,分析请求数据.设置断点.调试web应用.修改请求的 ...

  8. springcloud-断路器hystrix

    Netflix的创造了一个调用的库 Hystrix 实现了断路器.在微服务架构中,通常有多层服务调用. 底层服务出现故障可能导致用户级联故障.当调用特定服务达到一定阈值时(Hystrix中的默认值为5 ...

  9. 长期更新系列:C#知识点

    PS:写这个主要是基础差,写这么一个主要是为了自己查漏补缺,不会的搞会了.会了搞的更会.顺便整理知识. 目录 1.C#知识点:值类型和引用类型 2.C#知识点:I/0 3.C#知识点:is和as 4. ...

  10. Job控制台(elastic job lite console)

    elastic job lite console: 设计理念 1.本控制台和Elastic Job并无直接关系,是通过读取Elastic Job的注册中心数据展现作业状态,或更新注册中心数据修改全局配 ...