最近在整理我的小作业本,顺便翻到了Python内置库,
感觉自己在小本本上写的也挺凌乱的,索性一不做二不休,
重新整理!
小屌丝:鱼哥,你终于作对了一件有意义的事情。
小鱼:What
小屌丝:你脱什么你脱,赶紧分享干货!!
Python一共提供了68个内置函数,我们先看一下,都有哪些
abs() dict() help() min() setattr()
all() dir() hex() next() slice()
any() divmod() id() object() sorted()
ascii() enumerate() input() oct() staticmethod()
bin() eval() int() open() str()
bool() exec() isinstance() ord() sum()
bytearray() filter() issubclass() pow() super()
bytes() float() iter() print() tuple()
callable() format() len() property() type()
chr() frozenset() list() range() vars()
classmethod() getattr() locals() repr() zip()
compile() globals() map() reversed() __import__()
complex() hasattr() max() round()
delattr() hash() memoryview() set()
小屌丝:唉我去~~ 这么多,我怎么记得住?
小鱼:如果这68个内置库想象成妹子的兴趣爱好,然后对应12个妹子,你能能记住吗???
小屌丝:那…这… 必须能啊。
小鱼:… 你真的是…
小屌丝:有妹子,好办事! !
我们把这68个内置函数,分成12个大类,如下:
代码展示:
#输出结果:二进制:0b1010
print(bin(10))
#输出结果: 十六进制:0xa
print(hex(10))
#输出结果:八进制:0o12
print(oct(10))
代码展示:
# 绝对值:2
print(abs(-2))
# 求商和余数:(6,2)
print(divmod(20,3))
# 五舍六入:4
print(round(4.50))
#5
print(round(4.51))
# 如果给了第三个参数. 表示最后取余:1
print(pow(10,2,3))
# 求和:55
print(sum([1,2,3,4,5,6,7,8,9,10]))
#求最小值:2
print(min(5,3,9,12,7,2))
#求最大值:15
print(max(7,3,15,9,4,13))
1、列表和元组
代码展示:
#输出结果:[1, 2, 3, 4, 5, 6]
print(list((1,2,3,4,5,6)))
#输出结果:(1, 2, 3, 4, 5, 6)
print(tuple([1,2,3,4,5,6]))
2、相关内置函数
代码展示:
#定义list
lst = "你好啊"
# 不会改变原列表. 返回一个迭代器, 设计上的一个规则
it = reversed(lst)
#输出结果:['啊', '好', '你']
print(list(it))
#定义list
lst = [1, 2, 3, 4, 5, 6, 7]
#输出结果:[2,3]
print(lst[1:3:1])
#切片
s = slice(1, 3, 1)
#输出结果[2,3]
print(lst[s])
3、字符串
代码展示:
#输出结果:123456
print(str(123)+'456')
format() #与具体数据相关, 用于计算各种小数, 精算等
s = "hello world!"
#剧中
print(format(s, "^20"))
#左对齐
print(format(s, "<20"))
#右对齐
print(format(s, ">20"))
# 二进制:11
print(format(3, 'b' ))
# 转换成unicode字符:a
print(format(97, 'c' ))
# ⼗进制:11
print(format(11, 'd' ))
# 八进制:13
print(format(11, 'o' ))
# 十六进制(⼩写字母):b
print(format(11, 'x' ))
# 十六进制(大写字母):B
print(format(11, 'X' ))
# 和d⼀样:11
print(format(11, 'n' ))
# 和d⼀样:11
print(format(11))
# 科学计数法. 默认保留6位小数:1.234568e+08
print(format(123456789, 'e' ))
# 科学计数法. 保留2位小数(小写):1.23e+08
print(format(123456789, '0.2e' ))
# 科学计数法. 保留2位小数(大写):1.23E+08
print(format(123456789, '0.2E' ))
# 小数点计数法. 保留6位小数:1.234568
print(format(1.23456789, 'f' ))
# 小数点计数法. 保留2位小数:1.23
print(format(1.23456789, '0.2f' ))
# 小数点计数法. 保留10位小数:1.2345678900
print(format(1.23456789, '0.10f'))
# 小数点计数法. 很大的时候输出INF:1234.567890
print(format(1.23456789e+3, 'F'))
bs = bytes("今天吃饭了吗", encoding="utf-8")
#输出结果:b'\xe4\xbb\x8a\xe5\xa4\xa9\xe5\x90\x83\xe9\xa5\xad\xe4\xba\x86\xe5\x90\x97'
print(bs)
bytearray() #返回一个新字节数组. 这个数字的元素是可变的, 并且每个元素的值得范围是[0,256)
ret = bytearray("alex" ,encoding ='utf-8')
#输出结果:97
print(ret[0])
#输出结果:bytearray(b'alex')
print(ret)
#输出结果:#把65的位置A赋值给ret[0]
ret[0] = 65
#输出结果;#bytearray(b'Alex')
print(str(ret))
# 字母a在编码表中的码位:97
print(ord('a'))
# '中'字在编码表中的位置:20013
print(ord('中'))
# 已知码位,求字符是什么:A
print(chr(65))
print(chr(19999))
for i in range(65536):
#打印出0到65535的字符
print(chr(i), end=" ")
#输出结果:'@'
print(ascii("@"))
s = "今天\n吃了%s顿\t饭" % 3
print(s) #输出结果:今天# 吃了3顿 饭
print(repr(s)) # 原样输出,过滤掉转义字符 \n \t \r 不管百分号%
#输出结果:'今天\n吃了3顿\t饭'
frozenset() 创建一个冻结的集合,冻结的集合不能进行添加和删除操作。
len() 返回一个对象中的元素的个数
sorted() 对可迭代对象进行排序操作 (lamda)
语法:sorted(Iterable, key=函数(排序规则), reverse=False)
Iterable: 可迭代对象
key: 排序规则(排序函数), 在sorted内部会将可迭代对象中的每一个元素传递给这个函数的参数. 根据函数运算的结果进行排序
reverse: 是否是倒叙. True: 倒叙, False: 正序
代码展示:
lst = [5,7,6,12,1,13,9,18,5]
# sort是list里面的一个方法
lst.sort()
#输出结果:[1, 5, 5, 6, 7, 9, 12, 13, 18]
print(lst)
# 内置函数. 返回给你一个新列表 新列表是被排序的
ll = sorted(lst)
#输出结果:[1, 5, 5, 6, 7, 9, 12, 13, 18]
print(ll)
#倒序
l2 = sorted(lst,reverse=True)
#输出结果:[18, 13, 12, 9, 7, 6, 5, 5, 1]
print(l2)
#根据字符串长度给列表排序
lst = ['one', 'two', 'three', 'four', 'five', 'six']
def f(s):
return len(s)
l1 = sorted(lst, key=f, )
#输出结果:['one', 'two', 'six', 'four', 'five', 'three']
print(l1)
lst = ['one','two','three','four','five']
# 把索引和元素一起获取,索引默认从0开始. 可以更改
for index, el in enumerate(lst,1):
print(index)
print(el)
# 1
# one
# 2
# two
# 3
# three
# 4
# four
# 5
# five
#输出结果:True
print(all([1,'hello',True,9]))
#输出结果:True
print(any([0,0,0,False,1,'good']))
lst1 = [1, 2, 3, 4, 5, 6]
lst2 = ['醉乡民谣', '驴得水', '放牛班的春天', '美丽人生', '辩护人', '被嫌弃的松子的一生']
lst3 = ['美国', '中国', '法国', '意大利', '韩国', '日本']
print(zip(lst1, lst1, lst3)) #
for el in zip(lst1, lst2, lst3):
print(el)
# (1, '醉乡民谣', '美国')
# (2, '驴得水', '中国')
# (3, '放牛班的春天', '法国')
# (4, '美丽人生', '意大利')
# (5, '辩护人', '韩国')
# (6, '被嫌弃的松子的一生', '日本')
function: 用来筛选的函数。
①在filter中会自动的把iterable中的元素传递给function;
②然后根据function返回的True或者False来判断是否保留留此项数据 ,
Iterable: 可迭代对象。
def func(i): # 判断奇数
return i % 2 == 1
lst = [1,2,3,4,5,6,7,8,9]
#l1是迭代器
l1 = filter(func, lst)
#
print(l1)
#[1, 3, 5, 7, 9]
print(list(l1))
可以对可迭代对象中的每一个元素进行映射。
分别去执行 function
def f(i): return i
lst = [1,2,3,4,5,6,7,]
# 把可迭代对象中的每一个元素传递给前面的函数进行处理. 处理的结果会返回成迭代器
it = map(f, lst)
#输出结果:[1, 2, 3, 4, 5, 6, 7]
print(list(it))
def func():
a = 10
# 当前作用域中的内容
print(locals())
# 全局作用域中的内容
print(globals())
print("今天内容很多")
func()
# {'a': 10}
# {'__name__': '__main__', '__doc__': None, '__package__': None, '__loader__':
# <_frozen_importlib_external.SourceFileLoader object at 0x0000026F8D566080>,
# '__spec__': None, '__annotations__': {}, '__builtins__':
# (built-in)>, '__file__': 'D:/pycharm/练习/week03/new14.py', '__cached__': None,
# 'func': }
# 今天内容很多
for i in range(15,-1,-5):
print(i)
# 15
# 10
# 5
# 0
lst = [1,2,3,4,5]
it = iter(lst) # __iter__()获得迭代器
print(it.__next__()) #1
print(next(it)) #2 __next__()
print(next(it)) #3
print(next(it)) #4
#输入:8+9
s1 = input("请输入a+b:")
# 17 可以动态的执行代码. 代码必须有返回值
print(eval(s1))
s2 = "for i in range(5): print(i)"
# exec 执行代码不返回任何内容
a = exec(s2)
# 0
# 1
# 2
# 3
# 4
print(a) #None
# 动态执行代码
exec("""
def func():
print(" 我是Carl_奕然")
""" )
func() #我是Carl_奕然
code1 = "for i in range(3): print(i)"
# compile并不会执行你的代码.只是编译
com = compile(code1, "", mode="exec")
# 执行编译的结果
exec(com)
# 0
# 1
# 2
code2 = "5+6+7"
com2 = compile(code2, "", mode="eval")
print(eval(com2)) # 18
code3 = "name = input('请输入你的名字:')" #输入:hello
com3 = compile(code3, "", mode="single")
exec(com3)
print(name) #hello
#sep:打印出的内容用什么连接,end:以什么为结尾
print("hello", "world", sep="*", end="@") #输出结果:hello*world@
hash() : 获取到对象的哈希值(int, str, bool, tuple)。
hash算法:
hash表:用空间换的时间 比较耗费内存。
open() : 用于打开一个文件, 创建一个文件句柄
f = open('file',mode='r',encoding='utf-8')
f.read()
f.close()
__ import__() : 用于动态加载类和函数
# 让用户输入一个要导入的模块
import os
name = input("请输入你要导入的模块:")
__import__(name) # 可以动态导入模块
如果返回True, object有可能调用失败;
但如果返回False. 那调用绝对不会成功。
a = 10
print(callable(a)) #False 变量a不能被调用
def f():
print("hello")
print(callable(f)) # True 函数是可以被调用的
print(help(str)) #查看字符串的用途
#查看元组的方法
print(dir(tuple))
小屌丝:呦呵~ 这整理的,挺立正啊!
小鱼:这还行吧,毕竟我很谦虚的。
写到这里,Python的内置库函数,也算是整理的明明白白的了。
当然,我们也可以参照官方文档来学习,
但是,官方文档,没有小鱼写的这么生动活泼。
所以,小鱼建议,先收藏,在学习,毕竟,一次性记住这么多内置函数,有点难。
如果智商跟小鱼一样高,可以一试。
毕竟,超过50的,都是普通人