python基础语法11 内置模块time,datetime,random,os,sys,hashlib模块

time模块

在python的三种时间表现形式:
  1.时间戳: 给电脑看的。
    - 自1970-01-01 00:00:00到当前时间,按秒计算,计算了多少秒。

  2.格式化时间(Format String): 给人看的
    - 返回的是时间的字符串 2002-01-11

  3.格式化时间对象(struct_time):
    - 返回的是一个元组, 元组中有9个值:
      9个值分别代表: 年、月、日、时、分、秒、一周中第几天,一年中的第几天,夏令时(了解)

import time

# 1.获取时间戳(******)计算时间时使用
print(time.time())  # (*******)1573887159.1747248
# 2.获取格式化时间 (*******)拼接用户时间格式并保存时使用
# 获取年月日
print(time.strftime('%Y-%m-%d'))

# 获取年月日时分秒
print(time.strftime('%Y-%m-%d %H:%M:%S')) # 2019-11-16 14:50:08
# %X == %H:%M:%S
print(time.strftime('%Y-%m-%d %X')) ## 2019-11-16 14:50:08
print(time.strftime('%X'))         #14:54:25

# 获取年月
print(time.strftime('%Y/%m'))
3.获取时间对象 (****print(time.localtime())
# time.struct_time(tm_year=2019, tm_mon=11, tm_mday=16, tm_hour=14, tm_min=56, tm_sec=15, tm_wday=5, tm_yday=320, tm_isdst=0)
print(type(time.localtime()))   # <class 'time.struct_time'>
time_obj=time.localtime()
print(time_obj.tm_year) # 2019
print(time_obj.tm_mon)  # 11
res=time.localtime()
time.sleep(5)

#获取系统当前时间的格式化时间
print(time.strftime('%Y-%m-%d %H:%M:%S',time.localtime()))
# 2019-11-16 15:09:31
# 将时间对象转为格式化时间
print(time.strftime('%Y-%m-%d %H:%M:%S',res))
# 2019-11-16 15:09:26

# 将字符串格式的时间转为时间对象
res=time.strptime('2019-01-01','%Y-%m-%d')
print(res)
# time.struct_time(tm_year=2019, tm_mon=1, tm_mday=1, tm_hour=0, tm_min=0, tm_sec=0, tm_wday=1, tm_yday=1, tm_isdst=-1)

datetime模块

import datetime

# 获取当前年月日
print(datetime.date.today()) # (*******) 2019-11-16
#
# # 获取当前年月日时分秒
print(datetime.datetime.today()) # (*******) 2019-11-16 15:25:03.590939
#
time_obj = datetime.datetime.today()
print(type(time_obj))
print(time_obj.year)
print(time_obj.month)
print(time_obj.day)
#
# # 从索引0开始计算周一
# UTC
print(time_obj.weekday())  # 0-6
# ISO
print(time_obj.isoweekday())  # 1-7

# UTC时区
# 北京时间
print(datetime.datetime.now()) # (*******)
# 格林威治
print(datetime.datetime.utcnow())

日期/时间的计算 (*******)
  日期时间 = 日期时间 “+” or “-” 时间对象
  时间对象 = 日期时间 “+” or “-” 日期时间

# 日期时间:
current_time = datetime.datetime.now()
print(current_time)    # 2019-11-16 16:16:40.990100

# 时间对象
# 获取7天时间
time_obj = datetime.timedelta(days=7)
print(time_obj)    #7 days, 0:00:00

# 获取当前时间7天后的时间
# 日期时间 = 日期时间 “+” or “-” 时间对象
later_time = current_time + time_obj
print(later_time)    #2019-11-23 16:16:40.990100

# 时间对象 = 日期时间 “+” or “-” 日期时间
time_new_obj = later_time - current_time
print(time_new_obj)    #7 days, 0:00:00

random模块

import random

#随机获取1—9中任意的整数
res = random.randint(1, 9)
print(res)

#默认获取0——1之间任意小数
res2 = random.random()
print(res2)

#洗牌
#将可迭代中的值进行乱序
list1 = ['红桃A', '梅花A', '红桃Q', '方块K']
random.shuffle(list1) # 注意: 不可变类型不可被乱序

 # - list
  #可以对某个有索引的可迭代对象进行乱序

print(list1)   # ['方块K', '红桃A', '红桃Q', '梅花A']

#随机获取可迭代对象中的某一个值  
#random.choice(可迭代对象): 注意: 有索引的可迭代对象
# - list, tuple
list1 = ['红桃A', '梅花A', '红桃Q', '方块K'] res3 = random.choice(list1) print(res3) # 方块K
# 需求: 随机验证码
'''
需求: 
    大小写字母、数字组合而成
    组合5位数的随机验证码
    
前置技术:
    - chr(97)  # 可以将ASCII表中值转换成对应的字符
    # print(chr(101))
    - random.choice
'''


# 获取任意长度的随机验证码
def get_code(n):
    code = ''
    # 每次循环只从大小写字母、数字中取出一个字符
    # for line in range(5):
    for line in range(n):

        # 随机获取一个小写字母
        res1 = random.randint(97, 122)
        lower_str = chr(res1)

        # 随机获取一个大写字母
        res2 = random.randint(65, 90)
        upper_str = chr(res2)

        # 随机获取一个数字
        number = str(random.randint(0, 9))

        code_list = [lower_str, upper_str, number]

        random_code = random.choice(code_list)

        code += random_code

    return code


code = get_code(100)
print(code)
print(len(code))

OS模块

os与操作系统交互的模块

import os

# 需求: 获取当前项目根目录

# 获取当前文件中的上一级目录
DAY15_PATH = os.path.dirname(__file__)
print(DAY15_PATH)   #D:/oldboy_edu/python_code/day15
#
# # 项目的根目录,路径相关的值都用 “常量”
BASE_PATH = os.path.dirname(DAY15_PATH)
print(BASE_PATH)
#
# # 路径的拼接: 拼接文件 “绝对路径”
TEST_PATH = os.path.join(DAY15_PATH, '老男孩老师们的写真集.txt')
print(TEST_PATH) # D:/oldboy_edu/python_code/day15\老男孩老师们的写真集.txt
#拼接路径,反斜杠没事,程序会根据电脑系统(window/linux)自动调整
#
# # 判断“文件/文件夹”是否存在:若文件存在返回True,若不存在返回False
print(os.path.exists(TEST_PATH))  # True
print(os.path.exists(DAY15_PATH))  # True
#
# # 判断“文件夹”是否存在
print(os.path.isdir(TEST_PATH))  # False
print(os.path.isdir(DAY15_PATH))  # True
#
# # 创建文件夹
DIR_PATH = os.path.join(DAY15_PATH, '老男孩老师们的写真集')
os.mkdir(DIR_PATH)

# 删除文件夹: 只能删除 “空的文件夹”
os.rmdir(DIR_PATH)

# os.remove('D:/oldboy_edu/python_code/day15/老男孩老师们的写真集.txt') #删除文件
# 获取某个文件夹中所有文件的名字
teacher_list = os.listdir(r'D:\项目路径\python13期\day15\老男孩老师们的写真集')
print(teacher_list)   # ['egon.txt', 'sean.txt', 'tank.txt']

# enumerate(可迭代对象) ---> 得到一个对象,对象有一个个的元组(索引, 元素)
# 注意: 可迭代對象中若是字典,则取字典中所有的key

  #返回的enumerate对象 ---> 相当于迭代器对象
  #list(迭代器对象) ---> 列表

res = enumerate(teacher_list)   # [(0, 'egon.txt'), (1, 'sean.txt'), (2, 'tank.txt')]
print(list(res))

# 让用户选择文件
while True:
    # 1.打印所有老师的作品
    for index, name in enumerate(teacher_list):
        print(f'编号: {index} 文件名: {name}')

    choice = input('请选择想看的老师作品-->(头条影片: Jason写真) 编号:').strip()

    # 2.限制用户必须输入数字,数字的范围必须在编号内
    # 若不是数字,则重新选择
    if not choice.isdigit():
        print('必须输入数字')
        continue

    # 若是数字,往下走判断是否在编号范围内
    choice = int(choice)

    # 判断如果不在列表范围内,则重新选择
    if choice not in range(len(teacher_list)):
        print('编号范围错误!')
        continue

    file_name = teacher_list[choice]

    teacher_path = os.path.join(
        r'D:\项目路径\python13期\day15\老男孩老师们的写真集', file_name)

    print(teacher_path)

    with open(teacher_path, 'r', encoding='utf-8') as f:
        print(f.read())

sys模块

import sys
import os

# 获取当前的Python解释器的环境变量路径
print(sys.path)

# 将当前项目添加到环境变量中
BASE_PATH = os.path.dirname(os.path.dirname(__file__))
sys.path.append(BASE_PATH)
import sys
import os

# 获取当前的Python解释器的环境变量路径
print(sys.path)

print('==' * 100)
# 将当前项目添加到环境变量中
BASE_PATH = os.path.dirname(os.path.dirname(__file__))
sys.path.append(BASE_PATH)
print(sys.path)
print('==' * 100)

# 获取cmd终端的命令行  python3 py文件 用户名 密码
print(sys.argv)  # 返回的是列表['py文件', '用户名', '密码']

cmd_list = sys.argv

# 执行文件权限认证
if cmd_list[1] == 'ldc' and cmd_list[2] == '123':
    print('通过验证')
    print('开始执行逻辑代码')

else:
    print('用户名或密码错误,权限不足!')

 

 

 hashlib模块

- sha_256(了解)
hashlib是一个加密模块:
  内置了很多算法
  - MD5(*******): 不可解密的算法(2018年以前)

  摘要算法:
    - 摘要是从某个内容中获取的加密字符串
    - 摘要一样,内容就一定一样: 保证唯一性

    - 密文密码就是一个摘要

import hashlib

md5_obj = hashlib.md5()
# print(type(md5_obj))
str1 = '123'
# update中一定要传入bytes类型数据
md5_obj.update(str1.encode('utf-8'))

# 得到一个加密后的字符串
res = md5_obj.hexdigest()
# 202cb962ac59075b964b07152d234b70
print(res)

# 以上操作撞库有可能会破解真实密码
# 防止撞库问题: 加盐
import hashlib


def pwd_md5(pwd):  #
    md5_obj = hashlib.md5()
    # print(type(md5_obj))
    str1 = pwd  # '1234'
    # update中一定要传入bytes类型数据
    md5_obj.update(str1.encode('utf-8'))

    # 创造盐
    sal = '坦克怎么这么帅啊!'
    # 加盐
    md5_obj.update(sal.encode('utf-8'))

    # 得到一个加密后的字符串
    res = md5_obj.hexdigest()
    # eb1ca06cf5940e9fb6ef39100ec72c94
    return res

user_str2 = f'tank:{res}'

with open('user.txt', 'w', encoding='utf-8') as f:
    f.write(user_str2)

# 模拟用户登陆操作

# 获取文件中的用户名与密码
with open('user.txt', 'r', encoding='utf-8') as f:
    user_str = f.read()

file_user, file_pwd = user_str.split(':')

# 用户输入用户名与密码
username = input('请输入用户名:').strip()
password = input('请输入密码:').strip()  # 1234

# 校验用户名与密码是否一致
if username == file_user and file_pwd == pwd_md5(password):  # pwd_md5('1234')
    print('登陆成功')
else:
    print('登陆失败')

 

posted @ 2019-11-16 21:21  战斗小人  阅读(200)  评论(0编辑  收藏  举报