一 time与datetime模块
1、time
import time # 时间分为三种格式: # 1、时间戳:从1970年到现在经过的秒数 # 作用:用于时间间隔的计算 print(time.time()) # 1680886728.1569963 # 2、按照某种格式显示的时间:2022-07-06 17:12:11 # 作用:用于展示时间 print(time.strftime('%Y-%m-%d %H:%M:%S %p')) # 2023-04-08 00:58:48 AM print(time.strftime('%Y-%m-%d %X')) # 2023-04-08 00:58:48 # 3、结构化的时间 # 作用:用于单独获取时间某一部分 res = time.localtime() print(res) # time.struct_time(tm_year=2023, tm_mon=4, tm_mday=8, tm_hour=1, tm_min=1, tm_sec=52, tm_wday=5, tm_yday=98, tm_isdst=0) print(res.tm_mday) # 8
2、datetime
import datetime print(datetime.datetime.now()) # 现在的时间 # 2023-04-08 01:05:08.986442 print(datetime.datetime.now()+datetime.timedelta(days=3)) # 三天后的时间,-3就是三天前的时间 # 2023-04-11 01:05:08.986442 print(datetime.datetime.now()+datetime.timedelta(weeks=3)) # 三周后的时间,-3就是三周前的时间 # 2023-04-29 01:05:08.986442
3、时间模块需要掌握的操作(时间格式的转换)
# struct_time--->时间戳 import time s_time = time.localtime() print(time.mktime(s_time)) # 1680887720.0 # 时间戳--->struct_time tp_time = time.time() print(time.localtime(tp_time)) # time.struct_time(tm_year=2023, tm_mon=4, tm_mday=8, tm_hour=1, tm_min=15, tm_sec=20, tm_wday=5, tm_yday=98, tm_isdst=0) # 补充:世界标准时间与本地时间 # print(time.gmtime()) # 世界标准时间 # time.struct_time(tm_year=2023, tm_mon=4, tm_mday=7, tm_hour=17, tm_min=42, tm_sec=54, tm_wday=4, tm_yday=97, tm_isdst=0) # print(time.localtime()) # 本地时间,中国比标准时间早八个小时 # time.struct_time(tm_year=2023, tm_mon=4, tm_mday=8, tm_hour=1, tm_min=42, tm_sec=54, tm_wday=5, tm_yday=98, tm_isdst=0) # struct_time-->格式化的字符串形式的时间 s_time = time.localtime() print(time.strftime('%Y-%m-%d %H:%M:%S', s_time)) # 2023-04-08 01:42:54 # 格式化的字符串形式的时间--->struct_time print(time.strptime('2006-09-01 09:00:00', '%Y-%m-%d %H:%M:%S')) # time.struct_time(tm_year=2006, tm_mon=9, tm_mday=1, tm_hour=9, tm_min=0, tm_sec=0, tm_wday=4, tm_yday=244, tm_isdst=-1) # 真正需要掌握的只有一条:format string<----->时间戳 # '1987-09-14 07:00:01' # format string--->struct_time--->timestamp res = time.strptime('1987-09-14 07:00:01', '%Y-%m-%d %H:%M:%S') print(res) # time.struct_time(tm_year=1987, tm_mon=9, tm_mday=14, tm_hour=7, tm_min=0, tm_sec=1, tm_wday=0, tm_yday=257, tm_isdst=-1) res1 = time.mktime(res) + 7 * 86400 print(res1) # 559177201.0 # timestamp---->struct_time--->format string res2 = time.localtime(res1) res3 = time.strftime('%Y-%m-%d %H:%M:%S', res2) print(res3) # 1987-09-21 07:00:01 # 了解知识 # time.sleep(3) # 爬虫中模拟人 # import time # print(time.asctime()) # linx的时间格式 import datetime print(datetime.datetime.now()) # 2023-04-08 01:44:53.571292 print(datetime.datetime.utcnow()) # 世界标准时间 # 2023-04-07 17:44:53.571292 print(datetime.datetime.fromtimestamp(12345556662)) # 时间戳直接转换成格式化时间 # 2361-03-20 17:17:42
二 random模块
import random print(random.random()) # (0,1)float 大于0小于1的小数 print(random.randint(1, 3)) # [1,3] 大于等于1且小于等于3之间的整数 print(random.randrange(1, 3)) # [1,3) 大于等于1且小于3之间的整数 print(random.choice([1, 'aa', [4, 5]])) # 1或者'aa'或者[4,5] print(random.sample([1, 'xiaobao', [4, 5]], 2)) # 列表元素任意2个组合 print(random.uniform(1, 3)) # 大于1小于3的小数,如1.923455555 item = [1, 3, 4, 6, 8] random.shuffle(item) # 打乱item的顺序,相当于“洗牌” print(item)
应用:随机产生6位的大写字母和数字的验证码
# 函数功能 import random def make_code(size): res = '' for i in range(size): letter = chr(random.randint(65, 95)) number = str(random.randint(1, 10)) chars = random.choice([letter, number]) res += chars # 字符串拼接 return res print(make_code(8))
三 os模块
import os # ****** # 1、获取某一个文件夹下所有的子文件以及子文件夹的名字 res = os.listdir(r'E:\Python学习\python全栈学习\day58') for x in res: print(x) print(res) # 返回一个列表 # ****** # 2、统计文件大小 size = os.path.getsize(r'E:\Python学习\python全栈学习\day58') print(size, type(size)) # ****** os.remove(r'E:\Python学习\python全栈学习\day22\hello.text') os.rename(r'E:\Python学习\python全栈学习\day22\hello.text', r'E:\Python学习\python全栈学习\day22\xiaobao.text') # 重命名文件/目录 # 3、 应用程序--->向操作系统发指令,直接显示(类似于cmd,dos运行) os.system(r"dir d:") # 4、 产生的一个字典:key和value必须都为字符串 os.environ["aaaa"] = 'xiaobao' # 添进去后,软件全局变量用。'sys.path'是模块导入用,'PATH'是系统调用环境变量 print(os.environ) # 5、返回path规范化的绝对路径 print(os.path.abspath(r'C:/bbb/test.txt')) # C:\bbb\test.txt print(__file__) print(os.path.abspath(__file__)) # 6、将path分割成目录和文件名二元组返回 print(os.path.split(r'C:/bbb/ccc')) # ('C:/bbb', 'ccc'),返回一个有两个元素的元组 # ****** # 7、返回path的目录。其实就是os.path.split(path)的第一个元素 print(os.path.dirname(r'C:/bbb/ccc')) # C:/bbb,用到了模块导入中的环境变量动态分配中使用 # ****** # 8、返回path最后的文件名。如何path以/或\结尾,那么就会返回空值。即os.path.split(path)的第二个元素 print(os.path.basename(r'C:/bbb/ccc/ddd')) # ddd # 9、 如果path存在,返回True;如果path不存在,返回False print(os.path.exists(r'C:/bbb/ccc/')) # False print(os.path.exists(r'E:\Python学习')) # True # 10、如果path是绝对路径,返回True # True print(os.path.isabs(r"C:\Users\admin\PycharmProjects\s14\Day5\test4")) # ******* # 11、如果path是一个存在的文件,返回True,否则返回False print(os.path.isfile(r'E:\Python学习\python全栈学习\复习\random模块应用.py')) # True # ******* # 12、如果path是一个存在的目录,则返回True,否则返回False print(os.path.isdir(r'E:\Python学习\python全栈学习\复习')) # True # 13、返回path所指向的文件或者目录的最后存取时间 print(os.path.getatime(r'E:\Python学习\python全栈学习\复习')) # 1680922732.0183225 # 14、返回path所指向的文件或者目录的最后修改时间 print(os.path.getmtime(r'E:\Python学习\python全栈学习\复习\random模块应用.py')) # 1483510068.746478 # 15、无论linux还是windows,拼接出文件路径 put_filename = '%s%s%s' % ('self.home', os.path.sep, 'filename') print(put_filename) # self.home\filename
# os命令创建文件夹: E:/aaa/bbb/ccc/ddd并写入文件file1.txt import os os.makedirs('E:/aaa/bbb/ccc/ddd', exist_ok=True) # exist_ok=True:如果存在当前文件夹不报错。创建文件夹。 path = os.path.join('E:/aaa/bbb/ccc', 'ddd') print(path) f_path = os.path.join(path, 'file.txt') with open(f_path, 'w', encoding='utf8') as f: f.write('are you ok!!')
# 将其他目录的绝对路径动态的添加到pyhton的环境变量中
import os import sys print(os.path.dirname(os.path.dirname(os.path.abspath(__file__)))) BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) sys.path.append(BASE_DIR)
# 在python3.5之后,推出了一个新的模块pathlib from pathlib import Path # Path中得'p'是大写 res1 = Path(__file__) print(res1) res = res1.parent.parent print(res)
代码解释:
要想导入其他目录中的函数,其实就是将其他目录的绝对路径动态的添加到python的环境变量中,这样python解释器就能够在运行时找到导入的模块而不报错:
然后调用sys模块sys.path.append(BASE_DIR)就可以将这条路径添加到python环境变量中
四 sys模块
1 sys.argv 命令行参数List,第一个元素是程序本身路径 2 sys.exit(n) 退出程序,正常退出时exit(0) 3 sys.version 获取Python解释程序的版本信息 4 sys.maxint 最大的Int值 5 sys.path 返回模块的搜索路径,初始化时使用PYTHONPATH环境变量的值 6 sys.platform 返回操作系统平台名称
五 shutil模块(了解)
高级的 文件、文件夹、压缩包 处理模块
六 json&pickle模块
1、什么是序列化
内存中的数据类型---->序列化----->特定的格式(json格式或者pickle格式)
内存中的数据类型<----反序列化<-----特定的格式(json格式或者pickle格式)
土方法:
{'aaa':11}---->序列化str({'aaa':11})---->'{'aaa':11}'
{'aaa':11}<----序列化eval({'aaa':11})<----'{'aaa':11}'
2、为何要序列化
序列化得到的结果--->特定的格式的内容有两种用途
(1)可用于存储--->用于存档
(2)传输给其他平台使用--->跨平台数据交互
python java
列表 特定的格式 数组
强调:
针对用途1的特定一格式:可是一种专用的格式---->pickle只有python能识别
针对用途2的特定二格式:应该是一种通用、能够被所有语言识别的格式--->json
3、如何序列化与反序列化
# json序列化代码 import json info = [1, 'aaa', True, False] with open(r"test.txt", mode='w', encoding='utf-8') as f: print(json.dumps(info), type(json.dumps(info))) # 字符串格式 f.write(json.dumps(info)) # 反序列化,将文件反序列化到内存中 with open(r"test.txt", mode='r', encoding='utf-8') as f: res = f.read() print(json.loads(res), type(json.loads(res))) # 字符串格式 # json验证:json格式兼容的是所有语言通用的数据类型,不能识别某一语言的所独有的类型 # json.dumps({1,2,3,4}) # 集合报错 # json强调:一定要搞清楚json格式,不要与python混淆 # json格式的字符串是"",不是单引号,汉字是bytes模式表示 # 了解,python2.7和python3.5反序列化,可以加b import json res = '[1, "aaa", true, false]' l = json.loads(b'[1, "aaa", true, false]') print(l, type(l))
4、猴子补丁
# 在入口处打猴子补丁 import json import ujson def monkey_patch_json(): json.__name__ = 'ujson' json.dumps = ujson.dumps json.loads = ujson.loads monkey_patch_json() # 在入口文件处运行
5、pickle
import pickle info = { 'name': "tom", "age": "100" } f = open("test.txt", 'wb') f.write(pickle.dumps(info)) f.close() # pickle反序列化代码 import pickle f = open("test.txt", "rb") data = pickle.loads(f.read()) f.close() print(data["age"])
七 configparser模块
import configparser # 主要用于配置文件,setting用+ res = configparser.ConfigParser() res.read(r'E:\Python学习\python全栈学习\day23\test02.ini') # 1、获取sections print(res.sections()) # sections的列表 # ['section1', 'section2'] # 2、获取某一section下的所有options,就是获取key print(res.options('section1'))
# ['k1', 'k2', 'k3', 'k4'] # 3、获取items print(res.items('section1'))
# [('k1', 'xiaobao'), ('k2', 'lq'), ('k3', 'zd'), ('k4', 'cys1')] # 4、获取Value print(res.get('section1', 'k4'))
# cys1
八 hashlib模块
1、什么是哈希hash
hash一类算法,该算法接受传入的内容,经过运算得到一串hash值
hash值得特点:
1.1 只要传入的内容一样,得到的hash值必然一样--->要用明文传输密码文件完整性校验
1.2 不能由hash值反解成内容----->把密码做成hash值,不应该在网络传输明文密码
1.3 只能使用的hash算法不变,无论效验的内容有多大,得到的hash值长度是固定的
2、hash的用途
特点1.2用于账户密码密文传输与验证
特点1.1和1.2用于文件完整性效验
3、如何用
import hashlib m = hashlib.md5() m.update('hello'.encode('utf-8')) # 必须是Bytes类型数据 m.update('world'.encode('utf-8')) m.update(b'liuqiao') res = m.hexdigest() # 'helloworld'最终update合到一起的值 print(res) # 文件过大的情况,用for循环 # with open('wenjian',mode='rb') as f: # for line in f: # f.read() # m1.update(lin2) # 提高速度,用f.seek和read(2000) # 模拟撞库,前提是知道密码的哈希值,建密码库,对比哈希值得正确性。 cryptograph = 'f5656ef3fe3a9235162f0dc974031b66' password = [ 'liuhelloworld', 'he', 'helloworld', 'helloworldliuqiao', ] dic = {} for p in password: m = hashlib.md5(p.encode('utf-8')) dic[p] = m.hexdigest() print(dic) # 模拟撞库得到密码 for k, v in dic.items(): if v == cryptograph: print('撞库成功,密码是:', k) # 提升撞库的成本(密码加盐) m=hashlib.md5() m.update('zd'.encode('utf-8')) m.update('helloworldliuqiao'.encode('utf-8'))
九 suprocess模块
import subprocess # 系统调用命令,就是cmd # 'dir c:'查看文件信息的命令,'stdout'正确执行命令后内容,'stderr'是错误执行命令后的内容 obj = subprocess.Popen('dir c:', shell=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE, ) print(obj) res = obj.stdout.read() print(res.decode('gbk')) # 调用的系统命令,windows是默认的'gbk',解码要用'gbk' err_res = obj.stderr.read() print(err_res.decode('gbk'))
十 logging模块
看视频
十一 re模块
略
标签:常用,python,res,tm,模块,time,print,path,os From: https://www.cnblogs.com/coderxueshan/p/17297827.html