一、时间模块

时间模块优先掌握的操作

1、time

import time

时间分为三种格式:

1.1 时间戳:

从1970年到现在经过的秒数
作用:用于时间间隔的计算

print(time.time())

1.2 按照某种格式显示的时间:

2020-03-30 11:11:11
作用:用于展示时间

print(time.strftime(‘%Y-%m-%d %H:%M:%S %p’))
print(time.strftime(‘%Y-%m-%d %X’))

1.3 结构化的时间

作用:用于单独获取时间的某一部分

res=time.localtime()
print(res)
print(res.tm_year)
print(res.tm_yday)

2、datetime

import datetime

print(datetime.datetime.now())
print(datetime.datetime.now() + datetime.timedelta(days=3))
print(datetime.datetime.now() + datetime.timedelta(weeks=1))

3、时间模块需要掌握的操作

image.png

3.1 时间格式的转换

struct_time->时间戳
import time
s_time=time.localtime()
print(time.mktime(s_time))

时间戳->struct_time
tp_time=time.time()
print(time.localtime(tp_time))

补充:世界标准时间与本地时间
print(time.localtime())
print(time.gmtime()) # 世界标准时间,了解
print(time.localtime(333333333))
print(time.gmtime(333333333))

struct_time->格式化的字符串形式的时间
s_time=time.localtime()
print(time.strftime(‘%Y-%m-%d %H:%M:%S’,s_time))

print(time.strptime(‘1988-03-03 11:11:11’,’%Y-%m-%d %H:%M:%S’))

!!!真正需要掌握的只有一条:format string<———>timestamp

  1. # '1988-03-03 11:11:11'+7
  2. import time
  3. # format string--->struct_time--->timestamp
  4. struct_time=time.strptime('1988-03-03 11:11:11','%Y-%m-%d %H:%M:%S')
  5. timestamp=time.mktime(struct_time)+7*86400
  6. print(timestamp)
  7. format string<---struct_time<---timestamp
  8. res=time.strftime('%Y-%m-%d %X',time.localtime(timestamp))
  9. print(res)

time.sleep(3)

3.2 了解知识

  1. import time
  2. print(time.asctime()) # 多用于linux系统
  3. import datetime
  4. print(datetime.datetime.now())
  5. print(datetime.datetime.utcnow())
  6. print(datetime.datetime.fromtimestamp(333333))

二、radom模块

  1. import random
  2. print(random.random()) #(0,1)----float 大于0且小于1之间的小数
  3. print(random.randint(1, 3)) # [1,3] 大于等于1且小于等于3之间的整数
  4. print(random.randrange(1, 3)) # [1,3) 大于等于1且小于3之间的整数
  5. print(random.choice([111, 'aaa', [4, 5]])) # 1或者23或者[4,5]
  6. print(random.sample([111, 'aaa', 'ccc','ddd'],2)) # 列表元素任意2个组合
  7. print(random.uniform(1, 3)) # 大于1小于3的小数,如1.927109612082716
  8. item = [1, 3, 5, 7, 9]
  9. random.shuffle(item) # 打乱item的顺序,相当于"洗牌"
  10. print(item)

应用:随机验证码

import random
#
# res=’’
# for i in range(6):
# 从26大写字母中随机取出一个=chr(random.randint(65,90))
# 从10个数字中随机取出一个=str(random.randint(0,9))
#
# 随机字符=random.choice([从26大写字母中随机取出一个,从10个数字中随机取出一个])
# res+=随机字符

  1. import random
  2. def make_code(size=4):
  3. res=''
  4. for i in range(size):
  5. s1=chr(random.randint(65,90))
  6. s2=str(random.randint(0,9))
  7. res+=random.choice([s1,s2])
  8. return res
  9. print(make_code(6))

三、os模块

image.png
import os

获取某一个文件夹下所有的子文件以及子文件夹的名字
res=os.listdir(‘.’)
print(res)

size=os.path.getsize(r’/Users/linhaifeng/PycharmProjects/s14/day22/01 时间模块.py’)
print(size)

os.remove() 删除一个文件
# os.rename(“oldname”,”newname”) 重命名文件/目录

应用程序——》”ls /“
# os.system(“ls /“)

规定:key与value必须都为字符串
PATH #执行系统命令用到
sys.path #导模块用到
# os.environ[‘a aaaaaaaaa’]=’111’ #软件环境都用得到
# print(os.environ)

print(os.path.dirname(r’/a/b/c/d.txt’))
# print(os.path.basename(r’/a/b/c/d.txt’))

print(os.path.isfile(r’笔记.txt’))
# print(os.path.isfile(r’aaa’))
# print(os.path.isdir(r’aaa’))

print(os.path.join(‘a’,’/‘,’b’,’c’,’d’))

推荐用这种
BASEDIR=os.path.dirname(os.path.dirname(_file))
print(BASE_DIR)

BASEDIR=os.path.normpath(os.path.join(
# _file
,
# ‘..’,
# ‘..’
# ))
# print(BASE_DIR)

在python3.5之后,推出了一个新的模块pathlib
from pathlib import Path

res = Path(file).parent.parent
# print(res)

res=Path(‘/a/b/c’) / ‘d/e.txt’
# print(res)

四、sys模块

sys.argv 外部传参

  1. import sys
  2. # python3.8 run.py 1 2 3
  3. # sys.argv获取的是解释器后参数值
  4. print(sys.argv)

写复制命令

  1. import sys
  2. python3.8 run.py 1 2 3
  3. sys.argv获取的是解释器后参数值
  4. print(sys.argv)
  5. src_file=input('源文件路径: ').strip()
  6. dst_file=input('目标文件路径: ').strip()
  7. src_file=sys.argv[1]
  8. dst_file=sys.argv[2]
  9. # 判断
  10. with open(r'%s' %src_file,mode='rb') as read_f,\
  11. open(r'%s' %dst_file,mode='wb') as write_f:
  12. for line in read_f:
  13. write_f.write(line)
  14. python3.8 run.py src_file dst_file

打印进度条

  1. import time
  2. def progress(percent):
  3. if percent > 1:
  4. percent = 1
  5. res = int(50 * percent) * '#'
  6. print('\r[%-50s] %d%%' % (res, int(100 * percent)), end='')
  7. recv_size=0
  8. total_size=1025011
  9. while recv_size < total_size:
  10. time.sleep(0.01) # 下载了1024个字节的数据
  11. recv_size+=1024 # recv_size=2048
  12. # 打印进度条
  13. # print(recv_size)
  14. percent = recv_size / total_size # 1024 / 333333
  15. progress(percent)

五、shutil模块

image.png

六、json与pickle模块

1、什么是序列化&反序列化

内存中的数据类型——>序列化——>特定的格式(json格式或者pickle格式)
内存中的数据类型<——反序列化<——特定的格式(json格式或者pickle格式)

土办法:
{‘aaa’:111}—->序列化str({‘aaa’:111})——->”{‘aaa’:111}”
{‘aaa’:111}<—-反序列化eval(“{‘aaa’:111}”)<——-“{‘aaa’:111}”

2、为何要序列化

序列化得到结果=>特定的格式的内容有两种用途

  1. 可用于存储=》用于存档
  2. 传输给其他平台使用=》跨平台数据交互

    1. python java<br /> 列表 特定的格式 数组

    强调:
    针对用途1的特定一格式:可是一种专用的格式=》pickle只有python可以识别
    针对用途2的特定一格式:应该是一种通用、能够被所有语言识别的格式=》json

3、如何序列化与反序列化

示范1

  1. import json
  2. # 序列化
  3. json_res=json.dumps([1,'aaa',True,False])
  4. print(json_res,type(json_res)) # "[1, "aaa", true, false]"
  5. # 反序列化
  6. l=json.loads(json_res)
  7. print(l,type(l))

示范2:
import json

序列化的结果写入文件的复杂方法

  1. json_res=json.dumps([1,'aaa',True,False])
  2. # # print(json_res,type(json_res)) # "[1, "aaa", true, false]"
  3. with open('test.json',mode='wt',encoding='utf-8') as f:
  4. f.write(json_res)

将序列化的结果写入文件的简单方法

  1. with open('test.json',mode='wt',encoding='utf-8') as f:
  2. json.dump([1,'aaa',True,False],f)

从文件读取json格式的字符串进行反序列化操作的复杂方法

  1. with open('test.json',mode='rt',encoding='utf-8') as f:
  2. json_res=f.read()
  3. l=json.loads(json_res)
  4. print(l,type(l))

从文件读取json格式的字符串进行反序列化操作的简单方法

  1. with open('test.json',mode='rt',encoding='utf-8') as f:
  2. l=json.load(f)
  3. print(l,type(l))

json验证:
json格式兼容的是所有语言通用的数据类型,不能识别某一语言的所独有的类型
json.dumps({1,2,3,4,5})

json强调:一定要搞清楚json格式,不要与python混淆
l=json.loads(‘[1, “aaa”, true, false]’)
l=json.loads(“[1,1.3,true,’aaa’, true, false]”)
print(l[0])

了解
# l = json.loads(b ‘[1, “aaa”, true, false]’)
# print(l, type(l))

with open(‘test.json’,mode=’rb’) as f:
# l=json.load(f)

res=json.dumps({‘name’:’哈哈哈’})
# print(res,type(res))

res=json.loads(‘{“name”: “\u54c8\u54c8\u54c8”}’)
# print(res,type(res))

4、猴子补丁

在入口处打猴子补丁

  1. import json
  2. import ujson
  3. def monkey_patch_json():
  4. json.__name__ = 'ujson'
  5. json.dumps = ujson.dumps
  6. json.loads = ujson.loads
  7. monkey_patch_json() # 在入口文件出运行

import ujson as json # 不行

后续代码中的应用
# json.dumps()
# json.dumps()
# json.dumps()
# json.dumps()
# json.dumps()
# json.dumps()
# json.dumps()
# json.dumps()
# json.loads()
# json.loads()
# json.loads()
# json.loads()
# json.loads()
# json.loads()
# json.loads()
# json.loads()
# json.loads()
# json.loads()
# json.loads()

5、pickle模块

  1. import pickle
  2. res=pickle.dumps({1,2,3,4,5})
  3. print(res,type(res))
  4. s=pickle.loads(res)
  5. print(s,type(s))

七、configparser模块

获取配置文件的信息
import configparser

config=configparser.ConfigParser()
config.read(‘test.ini’)

1、获取sections
# print(config.sections())

2、获取某一section下的所有options
# print(config.options(‘section1’))

3、获取items
# print(config.items(‘section1’))

4、
# res=config.get(‘section1’,’user’)
# print(res,type(res))

res=config.getint(‘section1’,’age’)
# print(res,type(res))

res=config.getboolean(‘section1’,’is_admin’)
# print(res,type(res))

res=config.getfloat(‘section1’,’salary’)
# print(res,type(res))