python import上一级目录_Python中import导入上一级目录模块及循环import问题

import上一级目录的模块

python中,import module会去sys.path搜索,sys.path是个列表,并且我们可以动态修改。

要import某个目录的module,我们sys.path.insert(0,somedir)来加入搜索路径,就可以import了。

既然这样,要import上一级目录的module,可以sys.path.insert(0,parentdir)。

不过这种写绝对路径的方式,如果文件放到其它地方,就不行了。

所以用动态方法来获取上一级目录。

import os,sys

parentdir = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))

sys.path.insert(0,parentdir)

为什么用sys.path.insert(0,parentdir) 而不是用sys.path.append(parentdir)呢

因为是遍历搜索路径的,所以如果在其它路径里也有个同名的module,会import错。用sys.path.insert(0,parentdir)可以确保先搜索这个路径。

解决循环import的问题在python中常常会遇到循环import即circular import的问题。

现实中经常出现这种滑稽的情况,

安装无线网卡的时候,需要上网下载网卡驱动..

安装压缩软件的时候,从网上下载的压缩软件安装程序居然是被压缩了的..

循环依赖就类似于这种情况。

举个栗子,

在models.py中,

from server import db

class User(db.Model):

pass

在server.py中,

from flask import Flask

from flask.ext.sqlalchemy import SQLAlchemy

app = Flask(__name__)

app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:tmp/test.db'

db = SQLAlchemy(app)

from models import User

这样就产生了循环import的问题。

解决循环import的方法主要有几种。

1.延迟导入(lazy import)

即把import语句写在方法或函数里面,将它的作用域限制在局部。

这种方法的缺点就是会有性能问题。

2.将from xxx import yyy改成import xxx;xxx.yyy来访问的形式

3.组织代码

出现循环import的问题往往意味着代码的布局有问题。

可以合并或者分离竞争资源。

合并的话就是都写到一个文件里面去。

分离的话就是把需要import的资源提取到一个第三方文件去。

总之就是将循环变成单向。

更多Python中import导入上一级目录模块及循环import问题相关文章请关注PHP中文网!

本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值