导入自定义模块中的函数
基本语法
import module1[, module2[,... moduleN]]
当你导入一个模块,Python 解析器对模块位置的搜索顺序是:
- 当前目录
- 如果不在当前目录,Python 则搜索在 shell 变量 PYTHONPATH 下的每个目录。
- 如果都找不到,Python会察看默认路径。UNIX下,默认路径一般为/usr/local/lib/python/。
模块搜索路径存储在 system 模块的 sys.path 变量中。变量里包含当前目录,PYTHONPATH和由安装过程决定的默认目录。
实例
先创建一个a.py
:
def a(x):
print(x ** 2)
a(3)
再创建b.py
导入a
import a
a(2)
以上写法会报错,正确使用a
中的a()
函数的方法:
import a
a.a(2)
可以看到有两个输出,因为a
中的测试行a(3)
也会被运行,而且我们可以尝试一下 只b.py
中导入不运行会不会也执行a(3)
当然也会执行,所以我们通常的写法是把测试的内容放入 if __name__ == "__main__"
判断内:
def a(x):
print(x ** 2)
if __name__ == "__main__":
a(3)
导入自定义模块中的类
先创建c.py
定义一个类:
class C1:
def __init__(self, x=1, y=2):
self.x = x
self.y = y
def d(self):
return self.x + self.y
class C2:
def d(self, x, y):
return x - y
if __name__ == "__main__":
c = C1(1, 3)
print(c.d())
print(C2().d(9,3))
创建d.py
来调用c.py
中的类:
import c
x = c.C1(4,5)
print(x.d())
也可以只引入c.py
中的指定类:
from c import C2
print(C2().d(5,4))
使用别名:
from c import C2 as cc
print(cc().d(7,1))
导入内置模块
import math
print(dir(math));
dir() 函数一个排好序的字符串列表,内容是一个模块里定义过的名字。
返回的列表容纳了在一个模块里定义的所有模块,变量和函数。
安装、使用第三方模块
安装pip部分有所简化
安装pip3
apt install python-pip3
安装第三方模块,以requests
为例
pip3 install requests
使用requests
:
import requests
response = requests.get('https://www.baidu.com')
print(response.status_code) # 打印状态码
print(response.url) # 打印请求url
print(response.headers) # 打印头信息
print(response.cookies) # 打印cookie信息
print(response.text) # 以文本形式打印网页源码
print(response.content) # 以字节流形式打印
练习:制作一个计算运行时间的模块
已知,可以使用time
模块来计算运行时间,实例如下,要求改写成一个自定义模块,实现引入模块后能够计算指定代码区域的运行时间
import time
start=time.time()
#中间写需要计算时间的代码块
end=time.time()
print('Running time: %s Seconds'%(end-start))