一 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模块

# 一、动机
# 1.文本处理已经成为计算机常见工作之一
# 2.对文本内容的搜索,定位,提取是逻辑比较复杂的工作
# 3.为了快速方便的解决上述问题,产生了正则表达式技术
# 二、简介
# 1.定义
# 既文本的高级匹配模式,提供搜索,替换等功能。其本质是由一系列字符和特殊符号构成
# 的字串,这个字串即正则表达式。
# 2.原理
# 通过普通字符和有特定含义的字符,来组成字符串,用以描述一定的字符串规则,
# 比如:重复,位置等,来表达某类特定的字符串。进而匹配
s = 'hh:lqiao@qq.cn'
print(re.findall('\w+@\w+\.cn', s))
# ['lqiao@qq.cn']
# ps:正则表达式在python中也可以匹配中文
# 三、元字符使用
# 1、普通字符(除了元字符以外的普通字符,跟\w区分)
# 匹配规则:每个普通字符匹配其对应的字符
print(re.findall('ab', 'abcdefg'))
# ['ab'] # 2、或关系
# 元字符:|
# 匹配规则:匹配|两侧任意的正则表达式即可
print(re.findall('com|cn', 'https://www.baidu.com.cn'))
# ['com', 'cn'] # 3、匹配单个字符
# 元字符:.
# 匹配规则:匹配除换行外的任意一个字符
print(re.findall('张.丰', '张三丰,张四丰 张五丰'))
# ['张三丰', '张四丰', '张五丰'] # 4、匹配字符集
# 元字符:[字符集]
# 匹配规则:匹配字符集中的任意一个字符
# [abc#!好]表示[]中的任意一个字符
# [0-9],[a-z],[A-Z]表示区间内的任意一个字符
# [#?0-9a-z]混合书写,一般区间表达写在后面
print(re.findall('[aeiou]', 'How are you!'))
# ['o', 'a', 'e', 'o', 'u'] # 5、匹配字符集反集
# 元字符:[^字符集]
# 匹配规则:匹配除了字符集以外的任意一个字符
print(re.findall('[^0-9]', 'use 007 Port'))
# ['u', 's', 'e', ' ', ' ', 'P', 'o', 'r', 't'] # 6、匹配字符串开始位置
# 元字符:^
# 匹配规则:匹配目标字符串的开头位置
print(re.findall('^Jame', 'Jame,hello'))
# ['Jame']
print(re.findall('^Jame', 'hello,Jame,hello'))
# []未匹配到 # 7、匹配字符串的结束位置
# 元字符:$
# 匹配规则:匹配目标字符串的结尾位置
print(re.findall('Jame$', 'Hi,Jame'))
# ['Jame'] # 规则技巧:^和$必然出现在正则表达式的开头和结尾处。
# 如果两者同时出现,则中间的部分必须匹配整个目标字符串的全部内容,也叫完全匹配或叫绝对匹配
print(re.findall('^Jame$', 'Jame'))
# ['Jame'] # 8、匹配字符重复
# 元字符:*
# 匹配规则:匹配前面的字符出现0次或多次
print(re.findall('wo*', 'woooo~~w'))
# ['woooo', 'w'] *只控制o,o的0次或多次
print(re.findall('[A-Z][a-z]*', 'How are you Fine Jam')) # 小写字母重复多次或0次,大写字母开头
# ['How', 'Fine', 'Jam'] # 元字符:+
# 匹配规则:匹配前面的字符出现1次或多次
print(re.findall('[A-Z][a-z]+', 'Hello World')) # 小写字母出现一次以上
# ['Hello', 'World']
print(re.findall('[A-Z][a-z]+', 'I am Y'))
# [] 小写字母0次,所以匹配不出来 # 元字符:?
# 匹配规则:匹配前面的字符出现0次或1次
print(re.findall('-?[0-9]+', 'Jame,age;18,-26'))
# ['18', '-26']
print(re.findall('-?[0-9]+', '233 d d , -33,34 -44')) # 匹配数字,含负数
# ['233', '-33', '34', '-44'] print(re.findall('[^ ]+', 'Port-9 Error #404# %@ST')) # 除了空格以外的出现了一次或者多次
# ['Port-9', 'Error', '#404#', '%@ST'] # 元字符:{n}
# 匹配规则:匹配前面的字符出现n次
print(re.findall('1[0-9]{10}', 'Jame:13882334448')) # 1开头,数字出现10次
# ['13882334448']
print(re.findall('ab{3}', 'abb abbbb ab')) # b出现3次
# ['abbb'] # 元字符:{m,n}
# 匹配规则:匹配前面的字符出现m-n次
print(re.findall('[1-9][0-9]{5,10}', 'qq:1259296994')) # 5到10(含)的数都能收到
# # ['1259296994']
print(re.findall('[1-9][0-9]{5,10}', 'qq:1259296')) # 5到10(含)的数都能收到
# ['1259296']
# ['1259296994'] # 9、匹配任意(非)数字字符
# 元字符:\d\D
# 匹配规则:\d 匹配任意数字字符,\D匹配任意非数字字符
print(re.findall('\d{1,5}', 'Mysql:3306,http:80'))
# ['3306', '80']
print(re.findall('\D', 'Mysql:3306,http:80'))
# ['M', 'y', 's', 'q', 'l', ':', ',', 'h', 't', 't', 'p', ':']
print(re.findall('\D+', 'Mysql:3306,http:80'))
# ['Mysql:', ',http:'] # 10、匹配任意(非)普通字符
# 元字符:\w\W
# 匹配规则:\w匹配普通字符,\W匹配非普通字符
# 说明:普通字符指数字,字母,下划线,汉字,utf-8字符都可以
print(re.findall('\w+', 'server_port = 8888'))
# ['server_port', '8888']
print(re.findall('\W+', 'server_port = 8888'))
# [' = '] # 11、匹配任意(非)空字符
# 元字符:\s\S
# 匹配规则:\s 匹配空字符,\S匹配非空字符
# 说明:空字符指 空格\r\n\t\v\f字符
print(re.findall('\w+\s+\w+', 'hello world'))
# ['hello world']
print(re.findall('\S+', 'hello world'))
# ['hello', 'world'] # 12、匹配开头结尾位置
# 元字符:\A\Z
# 匹配规则:\A表示开头位置,\Z表示 结尾位置 # 13、匹配(非)单词的边界位置
# 元字符:\b\B
# 匹配规则:\b表示单词边界,\B表示非单词边界
# 说明:单词边界指数字字母(汉字)下划线与其他字符的交界位置
print(re.findall(r'\bis\b', 'This is a test.'))
# ['is']
# 总结
# 匹配字符:. [] [^] \d \D \w \W \s \S
# 匹配重复:* + ? {n} {m,n}
# 匹配位置:^ $ \A \Z \b \B
# 其他:| () \
# 四、正则表达式的转义
# 1、如果使用正则表达式匹配特殊字符则需要加\表示转义,就匹配元字符需要前面加\
# 2、在编程语言中,常使用原生字符串书写正则表达式避免多重转义的麻烦
# python字符串----》 正则 ------》 目标字符串
# '\\$\\d+' 解析为 \$\d+ 匹配 '$100'
# '\\$\\d+' 等同于 r'\$\d+'
# 五、贪婪模式和非贪婪模式
# 1、定义
# 贪婪模式:默认情况下,匹配重复的元字符总是尽可能多的向后匹配内容。比如:* + ? {m,n}
# 总是向0次和多次,会向多次索取;{m,n}可以实m次,但向n次索取
# 非贪婪模式(懒惰模式):让匹配重复的元字符尽可能少的向后匹配内容
# 2、贪婪模式转换为非贪婪模式
# 在匹配重复元字符后加'?'号即可
# *? +? ?? {m,n}?
print(re.findall(r'\(.+\)', '(abcd)efgh(higk)'))
# ['(abcd)efgh(higk)']
print(re.findall(r'\(.+?\)', '(abcd)efgh(higk)'))
# ['(abcd)', '(higk)']
# 六、正则表达式分组
# 1.定义
# 在正则表达式中,以()建立正则表达式的内部分组,子组是正则表达式的一部分,
# 可以作为内部整体操作对象 # 2.作用
# 可以被作为整体操作,改变元字符的操作对象
print(re.search(r'(ab)+', 'ababababab').group()) # +的作用不在b上了,是作用整体'ab'上
# ababababab
# 可以通过编程语言某些接口获取匹配内容中,子组对应的内容部分
print(re.search(r'(https|http|ftp|file)://\S+', 'https://www.baidu.com').group(1))
# https
# 3、捕获组
# 可以给正则表达式的子组起一个名字,表达该子组的意义。
# 这种有名称的子组即为捕获组。
# 格式:(?P<name>pattern)
print(re.search(r'(?P<pig>ab)+', 'ababababab').group('pig'))
# ab
# 一个正则表达式中可以包含多个子组
# 子组可以嵌套,但是不要重叠或者嵌套结构复杂
# 子组序列号一般从外到内,从左到右计数
# 七、正则表达式匹配原则
# 1、正确性,能够正确的匹配出目标字符串
# 2、排他性,除了目标字符串之外尽可能少的匹配其他内容
# 3、全面性,尽可能考虑到目标字符串的所有情况,不遗漏
# 八、正则表达式模块使用

参考:re模块

十二 uuid模块

https://www.cnblogs.com/liuqingzheng/articles/9872350.html

 

python基础十(常用模块)的更多相关文章

  1. 十八. Python基础(18)常用模块

    十八. Python基础(18)常用模块 1 ● 常用模块及其用途 collections模块: 一些扩展的数据类型→Counter, deque, defaultdict, namedtuple, ...

  2. python基础31[常用模块介绍]

    python基础31[常用模块介绍]   python除了关键字(keywords)和内置的类型和函数(builtins),更多的功能是通过libraries(即modules)来提供的. 常用的li ...

  3. Python全栈开发之路 【第六篇】:Python基础之常用模块

    本节内容 模块分类: 好处: 标准库: help("modules") 查看所有python自带模块列表 第三方开源模块: 自定义模块: 模块调用: import module f ...

  4. python基础之常用模块以及格式化输出

    模块简介 模块,用一砣代码实现了某个功能的代码集合. 类似于函数式编程和面向过程编程,函数式编程则完成一个功能,其他代码用来调用即可,提供了代码的重用性和代码间的耦合.而对于一个复杂的功能来,可能需要 ...

  5. Python基础之--常用模块

    Python 模块 为了实现对程序特定功能的调用和存储,人们将代码封装起来,可以供其他程序调用,可以称之为模块. 如:os 是系统相关的模块:file是文件操作相关的模块:sys是访问python解释 ...

  6. Day5 - Python基础5 常用模块学习

    Python 之路 Day5 - 常用模块学习   本节大纲: 模块介绍 time &datetime模块 random os sys shutil json & picle shel ...

  7. Python基础之常用模块

    一.time模块 1.时间表达形式: 在Python中,通常有这三种方式来表示时间:时间戳.元组(struct_time).格式化的时间字符串: 1.1.时间戳(timestamp) :通常来说,时间 ...

  8. Python基础5 常用模块学习

    本节大纲: 模块介绍 time &datetime模块 random os sys shutil json & picle shelve xml处理 yaml处理 configpars ...

  9. python基础(11)-常用模块

    re(正则)模块 常用方法 findall() 以列表返回所有满足条件的结果 import re print(re.findall('\d','a1b2c2abc123'))#['1', '2', ' ...

  10. Python基础之常用模块(三)

    1.configparser模块 该模块是用来对文件进行读写操作,适用于格式与Windows ini 文件类似的文件,可以包含一个或多个节(section),每个节可以有多个参数(键值对) 配置文件的 ...

随机推荐

  1. MySQL执行函数时报错:Illegal mix of collations (utf8mb4_general_ci,IMPLICIT) and (utf8mb4_0900_ai_ci,IMPLICIT) for operation 'find_in_set'

    执行函数时报错: Illegal mix of collations (utf8mb4_general_ci,IMPLICIT) and (utf8mb4_0900_ai_ci,IMPLICIT) f ...

  2. python使用pandas库读写excel文件

    操作系统 : Windows 10_x64 Python 版本 : 3.9.2_x64 平时工作中会遇到Excel数据处理的问题,这里简单介绍下怎么使用python的pandas库读写Excel文件. ...

  3. 机器学习基础06DAY

    模型检验-交叉验证 一般在进行模型的测试时,我们会将数据分为训练集和测试集.在给定的样本空间中,拿出大部分样本作为训练集来训练模型,剩余的小部分样本使用刚建立的模型进行预测. 训练集与测试集 训练集与 ...

  4. 2023年多校联训NOIP层测试7+【LGR-149-Div.3】洛谷基础赛 #2 & qw Round -1

    普及模拟3 \(T1\) 最大生成树 \(100pts\) 简化题意:给定一个 \(n(1 \le n \le 1 \times 10^5)\) 个点的完全图,给定各点的点权 \(a_i(1 \le ...

  5. NC15976 小C的周末

    题目链接 题目 题目描述 愉快的周末到了,小C和他的N-1个朋友买了M个游戏,游戏编号从1~M.每个游戏都是多人游戏,他们打算周末一起打游戏. 小C的每个朋友都决定好了要玩哪一款游戏(会有一组人打同一 ...

  6. LTspice XVII使用笔记

    安装 前往官网下载 https://www.analog.com/cn/design-center/design-tools-and-calculators/ltspice-simulator.htm ...

  7. 跨越千年医学对话:用AI技术解锁中医古籍知识,构建能够精准问答的智能语言模型,成就专业级古籍解读助手(LLAMA)

    跨越千年医学对话:用AI技术解锁中医古籍知识,构建能够精准问答的智能语言模型,成就专业级古籍解读助手(LLAMA) 介绍:首先在 Ziya-LLaMA-13B-V1基线模型的基础上加入中医教材.中医各 ...

  8. SIP协议解析

    起始行(start-line) INVITE sip:34020000001320000001@202.102.11.27:35611 SIP/2.0 请求消息的起始行包括三个参数,格式:Reques ...

  9. Ubuntu下docker部署

    使用docker进行容器化集成部署 远程服务器更新源 更新ubuntu的apt源 sudo apt-get update 安装包允许apt通过HTTPS使用仓库 sudo dpkg --configu ...

  10. ASP.NET 读取FTP文件流

    参考资料 ASP.NET 上传文件到共享文件夹 工具类代码 /// <summary> /// 读取ftp文件流 /// </summary> /// <param na ...