码迷,mamicode.com
首页 > 编程语言 > 详细

【原创】由于python的导入方式引起的深坑

时间:2016-12-22 19:33:15      阅读:171      评论:0      收藏:0      [点我收藏+]

标签:module   logger   不同的   判断   views   模块   modules   block   from   

目录结构:

test/

  sacc/

    __init__.py

    app.py

    logger.py

    /views

      __init__.py

      main.py

 

事情是这样的,logger里面是一个类LoggerFactory, 这个类里面有一个类变量保存着日志logger,同时有一个get函数和一个init函数,init函数负责初始化,get负责获取这个logger。

我在app.py初始化之后,并在随后的处理过程中打印了日志,app.py调用了main.py的函数,在main.py里面的函数中首先通过LoggerFactory调用get获取logger,然后打印输出。

出现了问题:

  在main里面获取的是None。

 

原因:

  我在app.py使用 from logger import LoggerFactory 导入LoggerFactory

  在main里面使用from sacc.logger import LoggerFactory 导入,sacc的父目录已经加入sys.path,所以是可以加载的。

  这俩种方式导入会导致在sys.modules中是俩个不同的模块,使用id(module_or_class)可以判断这俩个是不容的对象,因此导致main.py获取到的logger为None

 

附:

Python import 的搜索路径

  • 在当前目录下搜索该模块
  • 在环境变量 PYTHONPATH 中指定的路径列表中依次搜索
  • 在 Python 安装路径的 lib 库中搜索

 

【原创】由于python的导入方式引起的深坑

标签:module   logger   不同的   判断   views   模块   modules   block   from   

原文地址:http://www.cnblogs.com/pengyusong/p/6212167.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!