内置函数思维导图:https://www.processon.com/mindmap/5c10c08ae4b07c3e3334f22d
内置函数
作用域相关: locals() 返回当前作用域中的名字 globals() 返回全局作用域中的名字
迭代器相关: range() 生成数据 next() 迭代器向下执行一次,内部实际使用__next__()方法返回迭代器的下一个项目 iter() 获取迭代器,内部实际使用的是__iter__() 方法来获取迭代器
lst = ['今天星期三', "明天星期四", "马上星期五"]
it = lst.__iter__()
print(it.__next__())
print(it.__next__())
print(it.__next__())
it = iter(lst) # it = lst.__iter__()
print(next(it)) # it.__next__()
print(next(it))
print(next(it))
字符串类型代码的执行
eva l() 执行字符串类型的代码,并返回最终结果
print(eva l("2+2")) # 4
n = 8
print(eva l("2+n")) # 10
#eva l 是把字符串类型的数据作为代码进行执行
s = "18+2"
ret = eva l(s) # 执行字符串类型的代码
print(ret)
exec() 执行字符串类型的代码
s = "{'name':'alex', 'age':18, 'isMan':False}" # 字符串
# 把字符串类型的代码还原回字典, 列表, 元组
ret = eva l(s) # 侧重的有返回值
print(ret)
print(type(ret))
compile() 将字符串类型的代码编译.代码队形能够通过exec语句来执行或者eva l()进行求值
code = '''
for i in range(10):
if i % 2 == 0:
print(i)
'''
c = compile(code, "", "exec") # 预加载代码
# exec
exec(c) # 运行代码
匿名函数 lambda
匿名函数统一的名字就是 lambda
fn = lambda a, b : a + b # 定义一个很简单的函数. 复杂的函数不要用lambda
ret = fn(3, 5)
print(ret)
print(func)
print(fn)
使用场景: 配合着sorted, map, filter 一起使用
sorted 排序函数. 请你自己去定义排序的规则
sorted 排序函数. 让你自己去定义排序的规则
lst = [11,5,36,1,27,58]
s = sorted(lst) # 默认从小到大排序.
print(s)
lst = ["胡一菲", "张伟", "关谷神奇", "曾小贤吕小布", "诺澜"]
# 按照字符串长度排序
def func(s):
return len(s) # 返回长度
# 执行流程:
# 把可迭代对象中的每一项拿出来, 作为参数传递给后面key函数.
# 函数返回数字. 根据数字进行排序
s = sorted(lst, key=func)
print(s)
print(sorted(lst, key=lambda s:len(s) ))
lst = [
{"name":"alex", "shengao":150, "tizhong":250},
{"name":"wusir", "shengao":158, "tizhong":150},
{"name":"taibai", "shengao":177, "tizhong":130},
{"name":"ritian", "shengao":165, "tizhong":130},
{"name":"nvshen", "shengao":160, "tizhong":120},
{"name":"baolang", "shengao":183, "tizhong":190}
]
# 按照体重进行排序
print(sorted(lst, key=lambda dic:dic['tizhong'], reverse=True))
map 映射函数
map() 映射函数
lst = ["篮球球", "打打台球", "唱歌", "爬慌山", "步"]
m = map(lambda s: "爱好:"+s , lst)
print(list(m))