模块,模块就是封装了特殊功能的代码。
模块分为三种:
自定义模块
第三方模块
内置模块
1.自定义模块
自定义模块就是自己定义的模块,如何import自定义模块,如下:
(1)主程序与模块程序在同一目录下: 如下面程序结构: `-- src |-- mod1.py `-- test1.py 若在程序test1.py中导入模块mod1, 则直接使用import mod1或from mod1 import *;
(2)主程序所在目录是模块所在目录的父(或祖辈)目录 如下面程序结构: `-- src |-- mod1.py |-- mod2 | `-- mod2.py `-- test1.py 若在程序test1.py中导入模块mod2
可以使用 from mod2.mod2 import * 或import mod2.mod2.
(3)主程序导入上层目录中模块或其他目录(平级)下的模块 如下面程序结构: `-- src |-- mod1.py |-- mod2 | `-- mod2.py |-- sub | `-- test2.py `-- test1.py 若在程序test2.py中导入模块mod1和mod2。调用方式如下: import os import sys path = os.path.dirname(os.path.dirname(__file__)) #获取test2.py的根目录sub,然后再获取sub的根目录src sys.path.insert(0, path) #将src目录添加到环境变量 import mod1 import mod2.mod2
当解释器遇到 import 语句,如果模块在当前的搜索路径就会被导入。
搜索路径是一个解释器会先进行搜索的所有目录的列表。如果需要导入模块support,需要把命令放在程序的顶端
- 一个模块只会被导入一次
- python解释器依次从目录中一级级的去寻找所引入的模块
- 寻找模块的过程有点像环境变量,事实上也可以通过定义环境变量的方式来确定搜索的路径
- 搜索路径是python编译或者安装的时候确定的,安装新的库应该也会修改,搜索路径被存储在sys模块中的path变量
2. 第三方模块
如何安装第三方模块,有2种安装方式,如下:
第一种安装方式:
Python3种自带了pip3,Python2.7种自带了pip,前提是需要将pip3(scripts目录)添加环境变量。
pip3 install xxx 安装某个模块
pip list 查看已经安装的模块
pip uninstall xxx模块已卸载
第二种安装方式,手动安装:
先下载安装包,直接百度搜比如说python requests模块
解压安装包
在解压的目录下执行 python setup.py install
3. 内置模块
random模块
import random print(random.randint(1, 20)) #在1-19之间随机生成一个整数,随机 print(random.choice('abs123')) #随机取一个元素,随机可迭代对象:字符串、字典、list、元组 print(random.sample('abcdfgrtw12', 3)) #随机取几个元素,3是长度,['2', 'a', 'b'],返回结果是list类型 print(random.uniform(1, 9)) #随机浮点数,随机取1-9之间的浮点数,可指定范围,5.8791750348305625 print(random.random()) #随机0-1的浮点数,0.9465901444615425 random.shuffle([1, 2, 3, 4, 5, 6]) #随机打乱list的值,只能是list
生成随机8位验证码,要求必须包含大小写字母及数字
1 #使用交集判断随机生成的长度为8的数据。是否包含大小写字母和数字 2 def ran_data_set(): 3 all = string.ascii_letters + string.digits #生成包含大小写+数字 4 set_u = set(string.ascii_uppercase) #生成所有的大写字母 5 set_low = set(string.ascii_lowercase) #生成所有的小写字母 6 set_num = set(string.digits) #生成0-9的数字 7 res_set = set() #定义一个空set,向set写入随机生成的数据时,保证随机生成的8位元素不重复,导致长度不够8位 8 while len(res_set) < 8: #当数组的长度小于8时,添加元素到set,去除重复的元素 9 res_set.add(random.choice(all)) 10 #判断生成的随机数据中是否与大写、小写、数字都有交集 11 if res_set.intersection(set_u) and res_set.intersection(set_low) and res_set.intersection(set_num): #非0即真非空即真,判断是否包含大小写和数字 12 res_value = ''.join(res_set) #每个元素之间使用空相拼接 13 return res_value 14 else: 15 return ran_data_set() #如果不包含大写、小写、数字中任意一个,继续调用该函数,生成符合条件的随机数
os模块
常用方法如下:getcmd()、mkdir()、os.path.abspath()、system()、popen()、join()、os.pathdirname()等
import os print(os.getcwd()) #获取当前py文件所在的工作目录:E:python_workspacease-codeday6
os.chdir('../') #更改当前的工作目录
print(os.getcwd()) #更改后的目录:E:python_workspacease-code
print(os.mkdir('test01')) #在当前工作目录创建文件夹
print(os.mkdir('E:/python_workspace/base-code/test01')) #在其他目录下创建文件夹时,需要写绝对路径
print(os.makedirs(r'test02 est2')) #创建多层目录,若创建的父目录(test02)不存在,则创建成功 print(os.rmdir('test01')) #删除当前目录下的空文件夹,若文件夹有内容,则删除失败 #print(os.removedirs(r'test02 est2')) #删除多层文件夹,若文件夹下有文件,则删除失败 print(os.remove('ac.py')) #删除文件,若传入文件夹则抛出OSError异常
print(os.rename('a.py', 'ab.py')) #重命令,将a.py更改为ab.py print(os.listdir('.')) #打印当前目录下所有的文件,返回结果为list print(os.sep) #获取当前系统的路径分隔符 print(__file__) #打印当前文件的绝对路径 print(os.path.abspath('a.py')) #获取a.py的绝对路径 print(os.path.abspath(__file__)) #获取当前文件的绝对路径 print(os.path.dirname(__file__)) #获取当前文件的父级目录(也就是上一级目录信息) print(os.name) #获取当前系统的名称,win返回的是nt
os模块常用的popen、system、exists、join等。
os.system('ipconfig') #os.sysytem用来执行系统命令,运行ipconfig命令,直接显示 res = os.system('ipconfig) #执行系统命令的返回值,若命令执行成功则返回0 , 命令执行失败返回1 result = os.popen('ipconfig') print(result) #通过popen方式执行系统命令,返回值:<os._wrap_close object at 0x00000000007D22B0> print(result.read()) #获取系统执行命令的所有信息 print(os.path.exists('test01')) #判断文件或者目录是否存在,如果存在返回True print(os.path.isfile('ab.py')) #判断当前目录下,输入的是否是一个文件,如果是文件则返回True print(os.path.isdir('test01')) #判断是否是一个目录,如果是一个目录则返回True print(os.path.isabs('')) #如果path是绝对路径,返回True print(os.path.join('e:', os.sep, 'aa', 'abc.txt')) #拼接路径:e:aaabc.txt print(os.path.join('ac', 'test', 'python')) #ac estpython print(os.path.split('python_workspace/base-code/day6')) #分隔目录和文件名,返回结果为元组:('python_workspace/base-code', 'day6')
sys模块
import sys res = sys.argv #命令行参数,在Terminal输入命令:python rename.py b.txt 123 666 ,res接收到的结果为list,第一个元素是程序本身 sys.exit(0) #退出程序,正常退出时n=0 sys.maxint #最大的int值 sys.path #返回模块的搜索路径,初始化时使用PYTHONPATH环境变量的值 sys.platform #返回操作系统平台名称 sys.stdout.write('please:')#向屏幕输出一句话 val = sys.stdin.readline()[:-1]#获取输入的值
time模块
time&datetime模块主要用于时间操作,时间表示方式有:时间戳、格式化时间、时间元组
import time print(time.time()) #获取当前时间的时间戳 print(time.strftime('%Y%m%d %H%M%S')) #将时间元组转换为 格式化输出的字符串,可以调试自己需要的时间格式 print(time.localtime()) #将时间戳转换为时间元组,若不传时间戳,则默认获取当前时间的时间戳 print(time.localtime(1498056319)) #将时间戳转换为时间元组:time.struct_time(tm_year=2017, tm_mon=6, tm_mday=21, tm_hour=22, tm_min=45, tm_sec=19, tm_wday=2, tm_yday=172, tm_isdst=0) print(time.mktime(time.localtime())) #将时间元组转换为时间戳 time.sleep(2) #休眠时间 print(time.strptime('20170618 144037', '%Y%m%d %H%M%S')) #将格式化后的时间转换为时间元组 print(time.ctime(1498056319)) #将时间戳转换Wie格式化时间:Wed Jun 21 22:45:19 2017 print(time.asctime()) #将时间元组转换为格式化时间,Wed Jun 21 22:52:37 2017,标准时间
datetime模块
import datetime print(datetime.datetime.now()) #将当前时间格式化输出,类似time.strftime('%Y%m%d %H%M%S') print(datetime.datetime.now() + datetime.timedelta(2)) #2天后的时间2017-06-23 22:56:24.150894 print(datetime.datetime.now() + datetime.timedelta(-1)) #1天前的时间2017-06-20 22:56:45.05809
hashlib模块
该模块主要用于加密相关操作,在Python3种代替了md5和sha模块,主要提供SHA1、SHA224、SHA256、SHA384、SHA512、MDS算法等。
md5: 二进制格式的hash
import hashlib print(bytes('hello', encoding='utf-8')) #将字符串转换为字节,bytes类型 md = hashlib.md5() #创建md5对象,md的返回值:<md5 HASH object @ 0x00000000006C2710> md.update(b'hello') #将字符串转换为bytes类型,该方法没有返回值 print(md.digest()) #输出二进制格式的hash,加密后的结果:b']A@*xbcK*vxb9qx9dx91x10x17xc5x92'
md5: 十六进制hash
import hashlib print(bytes('hello', encoding='utf-8')) #将字符串转换为字节,bytes类型 md = hashlib.md5() #创建md5对象,md的返回值:<md5 HASH object @ 0x00000000006C2710> md.update(b'hello') #将字符串转换为bytes类型,该方法没有返回值 print(md.hexdigest()) #输出十六进制格式的hash,加密后的结果:5d41402abc4b2a76b9719d911017c592
SHA1: 十六进制hash
import hashlib ha = hashlib.sha1() #创建sha1对象 ha.update(b'hello') #进行加密 print(ha.hexdigest()) #输出十六进制格式的hash,加密后的结果:aaf4c61ddcc5e8a2dabede0f3b482cd9aea9434d
SHA256: 十六进制hash (SHA224、SHA384、SHA512等加密方法,写法类似,分别创建对应加密方式的对象即可)
import hashlib ha = hashlib.sha256() #创建sha256对象 ha.update(b'hello') print(ha.hexdigest()) #输出十六进制格式的hash,加密后的结果:2cf24dba5fb0a30e26e83b2ac5b9e29e1b161e5c1fa7425e73043362938b9824
使用md5加密方式,对密码进行加密,如下:
import hashlib def md5_pwd(pwd): md = hashlib.md5() md.update(bytes(pwd, encoding='utf-8')) #m.update() 将字符串转换为bytes类型,需要传入bytes类型才可进行加密操作 md_pwd = md.hexdigest() #将加密后的结果以16进制输出 return md_pwd print(md5_pwd('123456')) #加密后:e10adc3949ba59abbe56e057f20f883e
加盐
md5对简单密码加密的话,可以通过撞库方法进行破解,可以使用加盐方式对密码再次进行复杂加密,实现方法如下:
1 import hashlib 2 #加盐,对密码进行复杂加密 3 #盐值,由英文、特殊字符、中文随机组成 4 SALT = 'asdf@#$%^DFG@!随便' 5 6 def md5_test(pwd): 7 md = hashlib.md5() #创建md5对象 8 md.update(bytes(pwd, encoding='utf-8')) #将pwd转换为bytes类型 9 new_pwd = md.hexdigest() #将加密后的结果进行16进制输出 10 return new_pwd 11 12 if __name__ =='__main__': 13 #在MD5加密的基础上再次进行复杂加密 14 print(md5_test('123456'+SALT))