- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
大多数有关 Django 或 Flask 的教程和书籍都从文件中导入特定的类,而不是导入整个文件。
例如,从 wrtforms.validators
导入 DataRequiered
验证器是通过 from wtforms import validators
完成的,而不是通过 import wtforms.validators 导入的作为 valids
,然后使用 valids.DataRequiered
访问 DataRequiered
。
我的问题是:这有什么原因吗?
我想到了避免加载整个模块以进行计算/内存优化(这真的相关吗?)?或者只是为了让代码更具可读性?
最佳答案
My question is: Is there an reason for this ?
from module_or_package import something
是规范的 pythonic 习惯用法(当然,当您只想在当前 namespace 中导入 something
时)。
此外,import module_or_package.something
仅适用于 module_or_package
是一个包并且 something
一个子模块,它会引发 ImportError(No module named something)
如果something
是 module_or_package
中定义的函数、类或任何对象,如在 stdlib 中所示 os.path
(这是 os.package
的子模块)与 datetime.date
(这是 datetime
模块中定义的类):
>>> import os.path as p
>>> p
<module 'posixpath' from '/home/bruno/.virtualenvs/blook/lib/python2.7/posixpath.pyc'>
对比
>>>import datetime.date as d
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
ImportError: No module named date
thought to something like avoiding the loading a whole module for computation/memory optimization (is it really relevant?)
完全不相关 - 从模块导入给定名称需要导入整个模块。实际上,这个:
from module_or_package import something
只是语法糖
import module_or_package
something = module_or_package.something
del module_or_package
编辑:您在评论中提到
Right, but importing the whole module means loading it to the memory, which can be a reason for importing only a submodule/class
所以看来我没能阐明这一点:在Python中,你不能“仅导入子模块/类”,句号。
在Python中,import
, class
和def
都是可执行语句(实际上只是您可以使用函数和类“手动”执行操作的语法糖)。导入模块实际上包括执行模块顶层的所有代码(这将实例化 function
和 class
对象)并创建 module
对象(module
类型的实例),其属性将是通过import
在顶层定义的所有名称。 , def
和class
语句或通过显式赋值。只有当所有这些都完成后,您才能访问模块中定义的任何名称,这就是为什么,正如我上面所说的,
from module import obj
只是语法糖
import module
obj = module.obj
del module
但是(除非你做了一些愚蠢的事情,比如在模块中定义一个 TB 级的巨大字典或列表),这实际上并不需要那么多时间,也不会消耗太多内存,并且模块只是有效地执行 每个进程第一次导入时一次 - 然后它被缓存在 sys.modules
中因此后续导入仅从缓存中获取它。
此外,除非您主动阻止,否则 Python 将缓存模块的编译版本(.pyc 文件),并且仅在 .pyc 丢失或早于源 .py 文件时才重新编译它。
wrt/包和子模块,导入子模块也会执行包的__init__.py
并建立一个module
来自它的实例(IOW,在运行时,包也是 module
)。包初始值设定项通常相当短,而且实际上通常是空的 FWIW...
关于python - 从文件导入特定类而不是完整文件重要吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55260308/
什么是事物 事务是一种机制、一个操作序列,包含了一组数据库操作命令,并且把所有的命令作为一个整体一起向系统提交或撤销操作请求,即这组数据库命令要么都执行,要么都不执行。 事务是一个不可分割的工.作逻辑
什么是范式? 简言之就是,数据库设计对数据的存储性能,还有开发人员对数据的操作都有莫大的关系。所以建立科学的,规范的数据库是需要满足一些规范来优化数据数据存储方式。在关系型数据库中这些规范就可以称为范
什么是事物 事务是一种机制、一个操作序列,包含了一组数据库操作命令,并且把所有的命令作为一个整体一起向系统提交或撤销操作请求,即这组数据库命令要么都执行,要么都不执行。 事务是一个不可分割的工.作逻辑
什么是范式? 简言之就是,数据库设计对数据的存储性能,还有开发人员对数据的操作都有莫大的关系。所以建立科学的,规范的数据库是需要满足一些规范来优化数据数据存储方式。在关系型数据库中这些规范就可以称为范
我正在尝试修改网站的布局,但有时网站会使用 !important,有没有办法覆盖它?我似乎无法弄清楚如何在页面的 css 文件之后加载 css 内容脚本。 最佳答案 !important CSS 规则
这个问题在这里已经有了答案: How to override !important? (12 个答案) 关闭 9 年前。 我写了一些 html,并在第三方网站中注入(inject)了一些 css 样
好的,我在这里安装了一个 wordpress 主题(www.sullivansuccesscoaching.com/home ...我们需要/home,因为仍然有一个 index.html 隐藏了 w
我已经为我的 Wordpress 模板创建了一个覆盖原始 CSS 的自定义样式表。但是,在我的日历页面上,原始 CSS 具有使用 !important 声明设置的每个表格单元格的高度: td {hei
这个问题在这里已经有了答案: How to document deconstructed parameters with JsDoc (1 个回答) 关闭 5 年前。 我正在努力寻找对文档 ES6
我的网站使用 bootstrap 4 和我制作的 css 文件。 在这个 css 文件的底部,我放置了一些媒体查询: @media (max-width: 575px) { .address .c
可以将 background-position X 设置为 0 带有标志 !important 和背景位置 Y 不带 !important? 例如: background-position-x: 0
我只想在焦点状态下去掉下拉列表中的轮廓。看这张图 我尝试使用 !important 覆盖 Bootstrap ,但根本不起作用。只是检查开发工具,突然看到这个。 Bootstrap 也使用 !impo
这个问题在这里已经有了答案: How to override !important? (12 个答案) 关闭 1 年前。
发生了什么事?:我的 jQuery Accordion 的动画坏了。在关闭上一个选项卡之前短时间单击下一个选项卡后,它会显示之前打开的选项卡。动画也不滑动。 CSS:来自this answer /*
如何使用 javascript 或 CSS 覆盖样式“color: red”?我想让它成为“2px”而不是“1px”边框。 Lorem... 我无法向“div”添加类、id。这不
这个问题在这里已经有了答案: How to override !important? (12 个答案) 关闭 5 年前。
滚动有问题不想显示其内容,如果我这样做 #callCenter { position: fixed; z-index: 2411 !important; display: bl
序言 1、MySQL表操作(创建表,查询表结构,更改表字段等), 2、MySQL的数据类型(CHAR、VARCHAR、BLOB,等), 本节比较重要,对数据表数据进行查询操作,其中可能大
如何将!important添加到客户端包GWT中的gwt-image: 我有这个: @sprite .superButton{ gwt-image : 'superButton'; backg
请帮助我..我想验证表单并使用 ajax 发送。 验证没有 ''onsubmit="return validateForm(this);"'' 工作。 但是当表单正确时,它的发送表单(页面刷新..)请
我是一名优秀的程序员,十分优秀!