博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Flask 参数简介
阅读量:6203 次
发布时间:2019-06-21

本文共 2889 字,大约阅读时间需要 9 分钟。

我们都知道学习了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__这是为了告诉其他的掉用文件我们的路径

 

转载于:https://www.cnblogs.com/zhaoyunlong/p/10112978.html

你可能感兴趣的文章
添加课程
查看>>
Ant的实现原理
查看>>
JNI学习
查看>>
Android性能优化典范(二)
查看>>
什么是几何变换(Transform)
查看>>
代码大全
查看>>
数论概论(Joseph H.Silverman) 定理39.1 连分数的递归公式
查看>>
Extjs表单输入框异步校验的插件实现
查看>>
Query on a tree——树链剖分整理
查看>>
博客园作业4--数组
查看>>
马凯军201771010116《面向对象程序设计(java)》第四周学习总结
查看>>
[NOI2004]郁闷的出纳员
查看>>
安装mysql-connector-python
查看>>
【C语言】15-预处理指令1-宏定义
查看>>
火鸡堂 对 基于云的胜利冲锋队 为了交项目干杯 的 Beta 产品测试报告
查看>>
DataTable.ImportRow()与DataTable.Rows.Add()的区别
查看>>
mysql操作
查看>>
JavaScript设计模式: 对象创建
查看>>
The Master of Science degree in Computer Scienc
查看>>
使用Docker镜像
查看>>