在Python中,要想使自己写的代码规范、模块化,需要把代码和功能划分为不同的module文件,但是对于有些功能来说,划分为不同的模块会带来一定的不方便,比如数据库的访问,一般一个应用中对同一个数据库只会建立一个访问连接,所以需要在多个模块中共用这个连接对象,那么该如何应用呢?经过这几天的学习,终于掌握了其使用的方法。对高手来说也许不算什么,但是对我这个新手来说,算是一个较大的进步了。
#---------------------------------------------------------
A.py
global CONN_DB
CONN_DB = None
def connDB()
..... #创建数据库连接
#---------------------------------------------------------
B.py
imort A
A.connDB()
print A.CONN_DB
#---------------------------------------------------------
C.py
from A import *
connDB()
print CONN_DB
#---------------------------------------------------------
大家可以试验一下,B和C的结果是截然不同的
下面我说明一下原因
为什么结果会不一样??
在B.py打出的结果中,可以看出CONN_DB已经有值了,但是C.py中仍然是None
在于import A 和 from A import *两种的引用机制不同
import A 是指使用A中所有的属性和方法(即变量和函数),在B中使用时,一定要A.属性 A.方法来调用,这时候调用的是A中原有的内容
而from A import *是对A中所有属性和方法的引用,也就是A中所有属性和方法的一个备份,对于方法(即函数)可以正常使用,但是对于属性(即变量)的使用却有问题,
也就是说在A中的CONN_DB和C中的CONN_DB并不是同一个变量,只是在C开始的时候,把A的CONN_DB赋值给了CONN_DB,但是由于A中并没有调用connDB函数初始化CONN_DB,所以从A中复制到C的CONN_DB也是None,而C后面调用的connDB中初始化的却是A中的CONN_DB,所以C中的CONN_DB始终为None
如果想在C中使用CONN_DB的话,可以在A中这么写:
#---------------------------------------------------------
A.py
global CONN_DB
CONN_DB = None
def connDB()
..... #创建数据库连接
connDB() #调用一下,在别的模块reload本模块时,就已经给CONN_DB赋值了
#---------------------------------------------------------