https://www.processon.com/view/link/5b57e19ee4b0555b39c3411a
内置函数分为作用域相关(2).迭代器和生成器相关(3).其他(12).面向对象(9).基础类型相关(38).反射相关(4).
作用域相关:
locals() 返回当前作用域中的名字
glogals() 返回全局作用域中的名字
迭代器和生成器相关:
range() 生成数据
next() 迭代器向下执行一次,内部实际使用了__next__()方法返回迭代器的下一个项目
iter() 获取迭代器,内部实际使用的是__iter__()方法获取迭代器
其他相关:
1.字符串类型代码的执行
eval() 执行字符串类型的代码.并返回最终结果
例:
s = input("请输入:")
print(eval(s))
结果:
请输入:5+8+9
22
exec() 执行字符串类型的代码
例:
s ="""
for i in range(5):
print(i)
"""
print(exec(s))
结果:
0
1
2
3
4
None #执行print不返回内容
例:
exec ("""
for i in range(5):
print(i)
""")
结果:
0
1
2
3
4
compile()将字符串类型的代码变异.代码对象能够通过exec来执行或者eval进行求值
compile不会执行代码用exec或者eval去执行代码
compile()有三个参数:(1)要执行的代码,动态代码片段
(2)文件名,代码存放的文件名,当传入第一个参数时,第二个参数给个空就行
(3)模式有三种模式:exec(一般放一些流程语句)
eval(只存放一个求值表达式)
single(存放的代码有交互的时候)
例:
code1 = "for i in range(5):print(i)"
c1 = compile(code1,"",mode="exec")
exec(c1)
print(c1)
结果:
0
1
2
3
4
<code object <module> at 0x00000261F3E70300, file "", line 1>
例:
code2 = "1+2+5+3"
c2 = compile(code2,"",mode="eval")
a = eval(c2)
print(a) ==>11
例:
code3 = "name = input('请输入名字:')"
c3 = compile(code3,"",mode="single")
exec(c3)
print(name)
结果:
请输入名字:宋江
宋江
2.输入输出相关
input() 获取用户输入的内容
print() 打印输出
3.内存相关
hash() 获取到对象的哈希值(int.str.bool.tuple)
id() 获取到对象的内存地址
4.文件操作相关
open() 用于打开一个文件,创建一个文件句柄
5.模块相关
__import__() 用于动态加载类和函数
6.帮助
help() 函数用于查看函数或模块用途的详细说明
7.调用相关
callable() 用于检查一个对象是否可调用的.如果返回True,对象有可能调用;如果返回False,对象一定不会被调用
8.查看内置属性
dir() 查看对象的内置属性,访问的是对象中的__dir__()方法
基础数据相关:
1.数字相关
(1)数据类型
bool() 将给定的数据转换成bool值.如果不给值.返回False
int() 将给定的数据转换成int值.不给值,返回0
float() 将给定的数据转换成float值.也就是小数
complex() 创建一个复数.第一个参数为实部,第二个参数为虚部.或者第一个参数用字符串来描述
(2)进制转换
bin() 将给的参数转换成二进制
otc() 将给的参数转换成八进制
hex() 将给的参数转换成十六进制
(3)数学运算
abs() 返回绝对值
divmode() 返回商和余
round() 四舍五入
pow(a,b) 求a的b次幂,如果有三个参数.则求完次幂后的第三个数取余
sum() 求和
min() 求最小值
max() 求最大值
2.数据结构相关
(1)序列
列表和元组
list() 将一个可迭代对象转换成列表
tuple() 将一个可迭代对象转换成元组
相关内置函数
reverse() 将一个序列翻转,返回翻转序列的迭代器
slice() 列表的切片
字符串
str() 将数据转化成字符串
format() 与具体数据相关,用于计算各种小数,精算
例:字符串
print(format('text','<20')) ==>text #左对齐
print(format('text','>20')) ==> text #右对齐
print(format('text','^20')) ==> text #居中
例:数值
print(format(3,'b')) #二进制 ==>11
print(format(97,'c')) #转换成unicode字符 ==>a
print(format(11,'d')) #十进制 ==>11
print(format(11,'o')) #八进制 ==>13
print(format(11,'x')) #十六进制(小写字母) ==>b
print(format(11,'X')) #十六进制(大写字母) ==>B
print(format(11,'n')) #和d一样 ==>11
print(format(11)) #和d一样 ==>11
例:浮点数
print(format(123456789,'e')) #科学计算法,默认保留6位小数 ==>1.234568e+08
print(format(123456789,'0.2e')) #科学计数法,保留2位小数(小写) ==>1.23e+08
print(format(123456789,'0.2E')) #科学计数法,保留2位小数(大写) ==>1.23E+08
print(format(123456789,'f')) #小数点计数法.保留6位小数 ==>123456789.000000
print(format(123456789,'.2f')) #小数点计算法.保留2位小数 ==>123456789.00
print(format(123456789,'0.10f')) #小数点计算法.保留10位小数 ==>123456789.0000000000
print(format(123456789e+10000,'F')) #小数点计数法 ==>INF
bytes() 把字符串转化成bytes类型 参考前面编码和解码
bytearray() 返回一个新字节数组.这个数字里的元素是可变的,并且每个元素的1取值范围是[0,256)
memoryview() 查看bytes在内存中的情况
ord() 输入字符找带字符编码的位置
chr() 输入位置数字找出对应的字符
ascii() 是ascii码中的返回值,不是就返回\u...
repr() 返回一个对象的string字符串形式
(2)数据结构
dict() 创建一个字典
set() 创建一个集合
frozenset() 创建一个冻结集合.冻结的集合不能进行添加和删除操作
(3)相关内置函数
len() 返回一个对象中的元素个数
sorted() 对可迭代对象进行排序操作
语法:sorted(iterable,key=None,reverse=False) 在sorted内部会将可迭代对象中的每一个元素传递给这个函数的参数.根据函数的运算结果进行排序 reverse是否倒序
例:
lst = ["sdef","efg","c","sfrgrg"]
l = sorted(lst,key= lambda s : len(s))
print(l) ==>['c', 'efg', 'sdef', 'sfrgrg']
例:
lst = [{"name":"小花","age":6},
{"name":"jan","age":14},
{"name":"笨笨","age":4},
{"name":"曼曼","age":10}]
ll = sorted(lst,key = lambda dic:dic["age"])
print(ll)
结果:[{'name': '笨笨', 'age': 4}, {'name': '小花', 'age': 6}, {'name': '曼曼', 'age': 10}, {'name': 'jan', 'age': 14}]
enumerate() 获取集合的枚举对象
例:
lst = ["a","b","c","d"]
for i,el in enumerate(lst): #索引默认从0开始,可以更改
print(i,el)
结果:
0 a
1 b
2 c
3 d
all() 可迭代对象中全部是True,结果才是True 和and相同
any() 可迭代对象中有一个是True,结果才是True 和or相同
zip() 函数用于将可迭代的对象作为参数,将对象中对应的元素打包成一个个元组,然后返回由这些元组组成的列表,如果各个迭代器的元素个数不一致,则返回列表长度与最短的对象相同.
例:
l1 = [1,2,3,4]
l2 = [5,6,7,8]
l3 = ["a","b","c"]
for i in zip(l1,l2,l3):
print(i)
结果:
(1, 5, 'a')
(2, 6, 'b')
(3, 7, 'c')
filter() 过滤函数
语法:filter(function,iterable) function:用来筛选的函数,在filter中会自动把iterable中的元素传递给function,然后根据function返回的True或False来判断是否保留此项数据.iterable:可迭代对象
例:
def fn(i):
return i % 2 ==1
lst = [1,2,3,4,5,6,7,8,9]
ll = filter(fn ,lst)
print(list(ll)) ==>[1, 3, 5, 7, 9]
例:
lst = [1,2,3,4,5,6,7,8,9]
ll = filter(lambda i : i % 2 == 1 , lst)
print(list(ll)) ==>[1, 3, 5, 7, 9]
例:
lst = [{"id":1,"name":"alex","age":18},
{"id":2,"name":"taibai","age":58},
{"id":3,"name":"wusir","age":38},
{"id":4,"name":"ritian","age":48},
{"id":5,"name":"女神","age":18},]
ll = filter(lambda dic:dic["age"]<40 ,lst)
print(list(ll))
结果:[{'id': 1, 'name': 'alex', 'age': 18}, {'id': 3, 'name': 'wusir', 'age': 38}, {'id': 5, 'name': '女神', 'age': 18}]
map() 会根据提供的函数的指定序列做映射
语法:map(function,iteration) 可以对可迭代对象中的每一个元素进行映射.分别执行function
例:
lst = [1,2,3,4,5]
it = map(lambda i:i*i,lst)
print(list(it)) ==>[1, 4, 9, 16, 25]
例:
lst1 = [1,2,3,4,5]
lst2 = [6,7,8,9,10]
print(list(map(lambda x,y:x+y,lst1, lst2))) ==>[7, 9, 11, 13, 15]
lambda() 匿名函数:
lambda表示的是匿名函数,不需要用def来声明,一句话就可以声明一个函数
语法:函数名 = lambda 参数:返回值
注意:
(1)参数可以有多个,多个参数用逗号隔开
(2)匿名函数不管多复杂.只写一行.且逻辑结束后直接返回数据
(3)返回值和正常函数一样1,可以是任意数据类型
我们通过__name__()查看函数名字
例:
a = lambda x : x * x
print(a(5)) ==>25
print(a.__name__) ==><lambda>
例:
a = lambda x,y : x * 2 + y
print(a(2,8)) ==>12
递归:
在函数中调用函数本身.就是递归
例:
def fn():
print("我是谁?")
fn()
fn()
在python中递归的深度最大到998
递归应用:遍历树形结构,例如系统中的文件夹系统
例:
import os
filePath = "F:\python作业" #获取当前文件夹位置
def fn(filePath,n):
it = os.listdir(filePath) #打开文件夹
for el in it: #遍历文件夹中的文件夹
fg = os.path.join(filePath,el) #加入文件夹 获取到绝对路径
if os.path.isdir(fg): #判断该路径下文件是文件夹
print("\t"*n,el)
fn(fg,n+1) #继续进行相同操作 递归入口
else:
print("\t"*n,el) #递归出口
fn(filePath,0)
结果:
.idea
inspectionProfiles
misc.xml
modules.xml
python作业.iml
workspace.xml
18.07.02
day1.py
day1作业及默写.pdf
18.07.03
day2.py
day2作业.pdf
作业.py