python如何在一个模块中调用另一个模块中的变量

Python022

python如何在一个模块中调用另一个模块中的变量,第1张

python在一个模块中调用另一个模块中的变量步骤如下:

1、要实现变量的深度拷贝,需要使用到copy模块,导入这个模块。

2、定义一个列表变量A并进行赋值,然后将变量A赋值给变量B。

3、接着调用id()方法,分别打印变量A和变量B的id值,查看是否一致。

4、保存代码并直接使用Run这个python文件,发现打印的结果一致。

5、调用copy模块中的deepcopy()方法,按照对应的值赋值给变量C。

6、再次分别打印变量A和变量C的id值,结果发现它们不一致,说明这是深度拷贝。

sys.path是一个list,存放了当前所有import搜索的路径。

绝大多数情况下,首个元素是"",即空串,也就是说,当你import re的时候,首先搜索的是"re",这时候就会直接在当前目录搜索到re。如下图:

解决方法也有不止一个:

1,在当前目录创建一个子文件夹,例如mine,在mine里放一个__init__.py,不用有代码,空文件即可。使用的时候:import mine.re

2,在sys.path上做手脚,把第一个空串挪到最后面去:

import sys

sys.path = sys.path[1:]

sys.path.append("")

这样当前目录会跑到最后面去,从而达到最后搜索的目的。

不过这很可能有副作用,即你创建的模块,不能和前面搜索路径里的任何文件重名,否则会无法import你的模块。

这也是为什么默认把当前路径放在最前搜索的原因,因为是用户自己写的,显然优先级最高。

尽管就你的问题作出分析和提出一些可能的解决办法,但是严重不建议在实际工程起和系统模块重名的文件名,这是自找麻烦。

当然,研究探讨它的实现原理,始终是值得肯定的。

最后强调一下,当你在当前文件夹创建了一个sys.py时,方法2不好用!

Python 模块

模块让你能够有逻辑地组织你的Python代码段。

把相关的代码分配到一个 模块里能让你的代码更好用,更易懂。

模块也是Python对象,具有随机的名字属性用来绑定或引用。

简单地说,模块就是一个保存了Python代码的文件。模块能定义函数,类和变量。模块里也能包含可执行的代码。

例子

一个叫做aname的模块里的Python代码一般都能在一个叫aname.py的文件中找到。下例是个简单的模块support.py。

def print_func( par ):

print "Hello : ", par

return

import 语句

想使用Python源文件,只需在另一个源文件里执行import语句,语法如下:

import module1[, module2[,... moduleN]

当解释器遇到import语句,如果模块在当前的搜索路径就会被导入。

搜索路径是一个解释器会先进行搜索的所有目录的列表。如想要导入模块support.py,需要把命令放在脚本的顶端:

#!/usr/bin/python

# -*- coding: UTF-8 -*-

# 导入模块

import support

# 现在可以调用模块里包含的函数了

support.print_func("Zara")