首页 > 编程语言 >python基础十(常用模块)

python基础十(常用模块)

时间:2023-04-09 17:47:26浏览次数:43  
标签:常用 python res tm 模块 time print path os

一 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

相关文章

  • python Selenium自动化测试
    转载自https://blog.csdn.net/tangya3158613488/article/details/106902110 Selenium自动化测试什么是自动化测试自动化测试指软件测试的自动化,在预设状态下运行应用程序或者系统,预设条件包括正常和异常,最后评估运行结果。总的概括即:将人为驱动的测试行为转化为机器执行的......
  • abp(net core)+easyui+efcore实现仓储管理系统——模块管理升级(六十)
    Abp(netcore)+easyui+efcore实现仓储管理系统目录abp(netcore)+easyui+efcore实现仓储管理系统——ABP总体介绍(一)abp(netcore)+easyui+efcore实现仓储管理系统——解决方案介绍(二)abp(netcore)+easyui+efcore实现仓储管理系统——领域层创建实体(三) abp(netcore)+eas......
  • Linux常用操作命令总结
    一、基础知识1.1Linux系统的文件结构/bin二进制文件,系统常规命令/boot系统启动分区,系统启动时读取的文件/dev设备文件/etc大多数配置文件/home普通用户的家目录/lib32位函数库/lib6464位库/media手动临时挂......
  • 多表查询和python操作mysql
    目录多表查询的两种方法方法1:连表操作方法2:子查询小知识点补充说明可视化软件NaviCat多表查询练习题1、查询所有的课程的名称以及对应的任课老师姓名2.查询平均成绩大于八十分的同学的姓名和平均成绩3.查询没有报李平老师课的学生姓名4.查询没有同时选修物理课程和体育课程的学生......
  • Python DeprecationWarning: executable_path has been deprecated, please pass in a
    借鉴https://blog.csdn.net/lly1122334/article/details/106217320https://blog.csdn.net/qq_57377057/article/details/128463296https://blog.csdn.net/tangya3158613488/article/details/106902110 将之前谷歌浏览器的105版本替换为110版本解决Python:DeprecationWar......
  • Python正则表达式
    本章将介绍Python中正则表达式,本文将会基于Python的标准库re模块讲解正则表达式。1、正则表达式的基本使用1.1、re.search(正则表达式,待匹配文本)我们可以使用re.search查询待匹配文本中是否存在可以匹配上的字符串,直接上例子。importrematch=re.search(r'pytho......
  • python-matplotlib库
    学习过程中跟着敲的代码:importmatplotlib.pyplotaspltfrommatplotlib.imageimportimreadplt.rcParams["font.sans-serif"]=['ArialUnicodeMS']#设置字体#plt.rcParams["axes.unicode_minus"]=False#该语句解决图像中的“-”负号的乱码问题#x=np.arange(-n......
  • python获取某单元格的行和列
    解决问题:在读取excel时,假如读取到了我想要的数据,则返回它所在的行和列importopenpyxl#打开Excel文件并选择工作表wb=openpyxl.load_workbook(r'D:\Users\72036454\Desktop\test.xlsx')sheet=wb['Sheet1']#遍历整个工作表,查找特定值target_value='hello'......
  • Navicat软件、python操作MySQL
    目录Navicat软件1.软件简介2.navicat基本操作python操作MySQL1.链接、执行sql、关闭(游标)2.查询结果3.增删改查4.使用pymysql写一个注册和登录的案例Navicat软件1.软件简介第三方开发的用来充当数据库客户端的简单快捷的操作界面 无论第三方软件有多么的花里胡哨,底层的本质还......
  • Python 操作 MongoDB
    Python操作MongoDB目录Python操作MongoDB1MongoDB简介1.1NoSQL的优点/缺点1.2使用MongoDB注意事项1.3MongoDB数据类型2MongoDB命令2.1基础命令2.2集合的增删改查2.2.1增加2.2.2查询2.2.3改2.2.4删除3python操作MongoDB1MongoDB简介MongoDB是一个基于分......