1、常用函数
round() : 四舍五入
参数1:要处理的小数
参数2:可选,如果不加,就是不要小数,如果加,就是保留几位小数
abs() :绝对值函数
max() :列表、字符串,得到最大的元素
min() :列表、字符串,得到最小的元素
hex() : 给一个十进制,将其转化为十六进制
oct() :给一个十进制,转化为八进制
bin() :给一个十进制,转化为二进制
sum() :给一个列表,求和,列表中都是整型
pow() :pow(x, y) == x**y
divmod() : 得到一个元组,是商和余数
random
import random
random.函数名()
random() : 返回[0, 1) 之间的一个随机数
uniform() :[a, b]之间的一个随机小数
choice() :字符串、列表,随机弹出一个元素
randint() : [a, b]之间的一个整数
sample(lt, 3) : 字符串、列表,随机取出3个元素
shuffle(lt) : 将lt中元素的顺序,随机打乱,返回None
randrange(a,b,step):从a到b的以step为间隔的序列中随机选出一个整数
time
sleep() :1.5 2.5 整数小数都可以
math
e
pi
ceil() : 天花板, 向上取整
floor() :地板,向下取整
sqrt() : 平方根
degrees() : 将弧度转化为度
180 == pi
radians() : 将度转化为弧度
sys
sys.argv : 通过python 1.py 参数1 参数2 参数3
在代码中,就可以通过sys.argv来获取这些参数
os
os.system() : 可以执行终端的指令
windows下常用
cls : 清除屏幕
ipconfig : 查看ip地址
2、字符串函数(非常重要)
ord() :将ascii字符转化为十进制
chr() :将十进制转化为ascii字符
join() :
'*'.join(lt)
将列表中的所有字符串按照*进行拼接
往下这些函数都是字符串的函数,
使用方式1:字符串.函数名(参数) 推荐
使用方式1:str.函数名(字符串, 参数)
ljust(width, 字符) :总共width宽度,左对齐,右边补字符
rjust() :和ljust一样,这个是右对齐
center() : 居中显示,两边补字符
zfill() : 前面0填充
strip() : 默认取出两边的空白字符,有参数,去除指定字符
lstrip() :只去除左边的特定字符
rstrip() :只去除右边的特定字符
replace(old, new, 可选个数) :替换
将new替换old,第三个参数可选,替换几个
split() : 将字符串按照特定字符切割,将结果保存到列表中
splitlines() :将字符串按照换行进行切割
find() :字符串查找,查找第一次字符串出现的位置,如果找不到,返回 -1
rfind() : 从右边开始查找,出现的位置,如果没有,返回 -1
index(): 同find,找不到就报错
upper() :将字符串中所有字母变成大写
lower() :将字符串中所有字母变成小写
capitalize() :字符串首单词首字母大写
title() :每个单词首字母大写
swapcase() :大小写互换
count() :返回字符串1在字符串2中出现的次数
len() : 求字符串长度
startswith() : 判断是不是以某某字符串开头
endswith() :判断是不是以某某字符串结尾
自己测试:
isspace() :判断是不是空格
isalnum() : 判断是不是数字或者字母
isalpha() :判断是不是字母
isdecimal() :判断是不是数字
islower() : 判断是不是小写
isupper() :判断是不是大写
istitle() :判断每个单词是不是首字母大写
iscapital() :判断是否首字母大写
3、列表函数
append() : 向列表中追加一个元素
extend() :向列表中追加,但不是追加的整体,会拆分列表或者字符串
count() :统计列表中指定元素出现的次数
index() : 找到元素第一次出现的位置
insert() :向指定下标插入一个元素
pop() :默认弹出列表中最后一个元素,也可以根据下标弹出指定元素
remove() : 删除这个列表中第一个这个元素
clear() : 清空整个列表
reverse() : 将列表逆序
copy() : 拷贝一份列表
sort() : 排序,默认从小到大排列
sort(reverse=1) 从大到小排列
4、字典函数
get(): 查找字典是否存在键,存在返回键对应的值,不存在返回None
items() : 用在kv同时遍历
keys() :获取所有的键
values() : 获取所有的值
pop() : 根据键弹出键值对
clear() :清空字典
update() : 用一个字典去更新另一个字典
copy() : 字典的复制
popitem() : 弹出最后一个键值对
5、集合函数
add() : 添加一个元素
update() :添加一个列表或者元组(可迭代对象)
clear() : 清空整个集合
pop() : 随机弹出一个元素
remove() :删除一个元素,没有会报错
discard() : 删除一个元素,没有元素不报错
issubset() :是不是子集
issuperset() : 是不是母集
isdisjoint() : 是不是没有交集
__str__ 魔法方法,当打印对象的时候,会自动调用这个方法,这个方这个字符串,这个字符串一般都格式为当法必须返回一个字符串,然后当打印对象的时候,就会打印前对象的一些信息
高阶函数
map
lt = ['hello','baby','haha','world']
ret = list(map(len,lt))
print(ret)
5 4 4 5
将函数依次作用与列表中每个元素
filter 过滤
依次作用与列表中每个元素,如果是真留下,
如果是假,返回false干掉
lt = [1,2,3,4,5,6,7,8,9]
ret = list(filter(lambda x:x %2 = 0,lt))
print(ret)
lt = ['','baby','haha','','love','','dudu']
ret = list(filter(lambda x:boll(x),lt))
print(ret)
reduce 学习
需要先导入
from functools import reduce
lt = [1,2,3,4,5,6,7]
ret = reduce(lambda x,y:x+y,lt)
print(ret)
得出所有数得和,
用在下例较好
lt1 = [1,3,9,8]
ret = reduce(lambda x,y : x*10 +y,lt1)
print(ret)
x = 1
y = 3
计算过程
1*10 +3
13*10+9
139*10+8
super().work() 调用的是上一级的work方法
父类名.work(self) 调用指定父类的work方法
__name__ : 通过类名调用,获取类名字符串
__dict__ : 通过对象名调用,可以获取到对象的所有属性
通过类名调用,可以获取类的所有详细信息
__bases__ :通过类名调用,获取所有的父类
限制属性动态添加
写个类属性
__slots__ = ('age', 'name', 'height')
说明对象动态添加属性,只能添加上面三个,其它不能添加
__del__ : 在对象销毁之前执行的方法,这里面一般做一些临终的操作,比如关闭文件,关闭数据库链接
pickle(常用)
问题:内存(程序、软件、操作系统都运行在内存中,断电消失)、硬盘(持久化保存)
作用:将对象序列化保存到文件中
用法:
import pickle
# 将对象保存到文件中,fp要以wb方式打开
pickle.dump(obj, fp)
# 将文件中内容读到内存中, fp要以rb方式打开
obj = pickle.load(fp)
obj就是那个类的对象
hashlib模块
md5加密:加密过后,生成一串32位的字符串
指定字符串加密生成的都是唯一的32位字符串
hash = hashlib.md5()
hash.update('admin'.encode('utf-8'))
tmp = hash.hexdigest()
目录管理
import os 模块
os.name : 当前操作系统
os.environ : 显示所有而环境变量
os.environ.get() :获取指定的环境变量
下面的用法和字符串、列表函数一样程度
os.getcwd() : 得到当前文件所在的路径
os.listdir() : 列出当前目录下所有的文件,返回一个列表,列表中都是文件名字符串
directory : 文件夹、目录
以c、d、e等开头的路径称之为绝对路径
相对路径:./ 代表的当前目录 ../ 代表的上一级目录
/ : 正斜杠
: 反斜杠
windows:目录分隔符可以使用正斜杠,也可以使用反斜杠
linux:目录分隔符只能使用正斜杠
os.mkdir() : 创建文件夹
路径给绝对、相对都可以
如果文件夹存在,再次创建,报错
所以一般情况,创建的时候要做判断,判断文件夹存在不存在,不存在在创建
os.makedirs() : 可以递归创建中间目录
os.rmdir() :只能删除空目录
如果目录非空:递归删除
python的shutil模块(可以实现多层级目录递归删除或其他操作)
os.stat() :查看文件或者文件夹的状态
os.rename() :修改文件或者文件夹名字
os.remove() :删除文件,
os.system() :执行系统指令
os.path.abspath(path) #返回绝对路径
os.path.basename(path) #返回文件名
os.path.commonprefix(list) #返回list(多个路径)中,所有path共有的最长的路径。
os.path.dirname(path) #返回文件路径
os.path.exists(path) #路径存在则返回True,路径损坏返回False
os.path.lexists #路径存在则返回True,路径损坏也返回True
os.path.expanduser(path) #把path中包含的"~"和"~user"转换成用户目录
os.path.expandvars(path) #根据环境变量的值替换path中包含的”$name”和”${name}”
os.path.getatime(path) #返回最后一次进入此path的时间。
os.path.getmtime(path) #返回在此path下最后一次修改的时间。
os.path.getctime(path) #返回path的大小
os.path.getsize(path) #返回文件大小,如果文件不存在就返回错误
os.path.isabs(path) #判断是否为绝对路径
os.path.isfile(path) #判断路径是否为文件
os.path.isdir(path) #判断路径是否为目录
os.path.islink(path) #判断路径是否为链接
os.path.ismount(path) #判断路径是否为挂载点()
os.path.join(path1[, path2[, ...]]) #把目录和文件名合成一个路径
os.path.normcase(path) #转换path的大小写和斜杠
os.path.normpath(path) #规范path字符串形式
os.path.realpath(path) #返回path的真实路径
os.path.relpath(path[, start]) #从start开始计算相对路径
os.path.samefile(path1, path2) #判断目录或文件是否相同
os.path.sameopenfile(fp1, fp2) #判断fp1和fp2是否指向同一文件
os.path.samestat(stat1, stat2) #判断stat tuple stat1和stat2是否指向同一个文件
os.path.split(path) #把路径分割成dirname和basename,返回一个元组
os.path.splitdrive(path) #一般用在windows下,返回驱动器名和路径组成的元组
os.path.splitext(path) #分割路径,返回路径名和文件扩展名的元组
os.path.splitunc(path) #把路径分割为加载点与文件
os.path.walk(path, visit, arg) #遍历path,进入每个目录都调用visit函数,visit函数必须有3个参数(arg, dirname, names),dirname表示当前目录的目录名,names代表当前目录下的所有文件名,args则为walk的第三个参数
os.path.supports_unicode_filenames #设置是否支持unicode路径名
mktime() : 将一个时间元组,转化为时间戳
时间元组是9个值,前六个必须写,后面3个都写0就行了
gmtime() : 给一个时间戳,返回时间元组,得到的时间为格林威治时间
东八区 :需要在0时区的基础上加8个小时
格林威治时间 :0时区的时间
localtime() : 如果不传递参数,获取当前时间的时间元组,如果传递参数,获取指定时间的时间元组,得到的是当前时区的时间元组
asctime() : 给一个时间元组,返回指定格式的时间字符串,如果不给,默认为当前时间
timezone :0时区-当前时区秒数的差值
日期模块
import datetime
dt_now = datetime.datetime.now() 当前日期和时间的日期时间字符串
dt_ziding = datetime.datetime() 获取指定日期和时间的日期时间字符串
dt.strftime() 转化为指定格式的日期和时间
dt.date() :获取日期对象中的日期
dt.time() :获取日期对象中的时间
dt.timestamp() : 获取日期对象的时间戳
dt.hourminutesecond : 获取日期对象的时间信息
datetime.datetime.fromtimestamp() : 给一个时间戳,返回指定的日期对象
datetime.timedelta() : 参数有 days, hours, minutes, seconds, 获取一个日期差值对象,这个对象可以直接和日期对象进行加减操作
重点:
(1)知道什么是时间戳
(2)知道什么是东八区、0时区
(3)时间戳和日期时间的相互转化
(4)如何转化为指定格式时间
(5)日期对象的加减操作
日历模块
import calendar
calendar(year, w=2, l=1, c=6) 查看指定年份所有日历
isleap(year) : 判断这个年份是不是闰年
leapdays(y1, y2) : 计算y1-y2之间所有的闰年
month(year, month, w=2, l=1) 查看指定年份月份的日历
hashlib模块
md5加密:加密过后,生成一串32位的字符串
指定字符串加密生成的都是唯一的32位字符串
hash = hashlib.md5()
hash.update('admin'.encode('utf-8'))
tmp = hash.hexdigest()