赞
踩
摘要:
- importlib.import_module 函数的功能
- import_string 函数的实现
今天开始来读 Django 的代码,首先想在 Django 内部设置一个logger用来打印调试日志,结果发现在Django内部,DEBUG日志显示不出来,然后我就想这肯定是Django配置日志的时候,根据logger的名字,来确定了一定的日志级别。
于是我就想看看Django的日志是如何配置的,顺着manage.py
中的execute_from_command_line
一路往下找,就找到了django.utils.log.configure_logging
函数,在这个函数中,第一个就遇到了import_string
函数,虽然一眼就能看出,这个函数的功能就是通过字符串来导入相应的函数的,但还是忍不住想要看一下它的实现,千里之行,始于足下,阅读Django源码的过程,就从这个11行的函数开始吧。
import_module
函数函数声明: importlib.import_module(name, package=None)
package
来确认执行相对导入时的当前路径。importlib.invalidate_caches
函数,来确保让导入系统能够发现新的模块。import_string
函数import_string
函数的代码如下所示:
def import_string(dotted_path):
try:
module_path, class_name = dotted_path.rsplit('.', 1)
except ValueError as err:
raise ImportError("%s doesn't look like a module path" % dotted_path) from err
module = import_module(module_path)
try:
return getattr(module, class_name)
except AttributeError as err:
raise ImportError('Module "%s" does not define a "%s" attribute/class' % (
module_path, class_name)
) from err
从代码中我们可以看出,这个函数其实很简单,就是首先将要导入的路径名分割成模块名和类名,然后再来从模块中获得到类这个属性,然后就完成了。照着这个思路来看,其实我们导入一个函数也是可以的。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。