首页 > 技术文章 > python 常用函数集合

loren880898 2019-04-25 14:51 原文

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.hour\minute\second : 获取日期对象的时间信息
     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()

推荐阅读