Python从入门到精通之eighth!

时间:2022-04-28 17:17:09

函数式编程与内置函数

函数作用域:

def test1():
print('in the test1')
def test():
print('in the test')
return test1() res = test()
print(res()) =========因为test中没有return值,所以默认为NONE.
name = 'alex'
def foo():
name='xtjiayou'
def bar():
print(name)
return bar
a = foo()
print(a)
#return bar与return bar()不同,第一个是返回函数的内存地址,第二个是返回
xtjiayou
None name = 'alex'
def foo():
name='linhaifeng'
def bar():
print(name)
return bar
a = foo()
print(a)
a() #a()执行bar内存地址不所存储的代码 ===========
<function foo.<locals>.bar at 0x000002067F719840>
linhaifeng

注意:以上面代码为准foo()()相当于执行了a =foo()  a()的作用。依次类推若有多层return 函数名(没有括号),可以使用多个括号,进行执行内存地址中代码。

示例:

def foo():
name = 'xtznb'
print(name)
def bar():
name = 'xtcnb'
print(name)
def tt():
print(name)
return tt
return bar
r1 = foo()
r2 = r1()
r3 = r2()
==============#或者把后三句改为r1 = foo()()()
xtznb
xtcnb
xtcnb

匿名函数:不应该独立存在,应该与其他函数共同使用。

定义方法:lambda 形式参数: 代码

 #利用赋值语句,进行引用匿名函数,但一般不这么用。
func = lambda x:x+1
print(func(10)) name = 'alex'
def change_name():
return name+'_sb' fo = lambda x:x+'_sb'
fo(name)
==========>>alex_sb 匿名函数和自定义函数作用一样,但更简洁,只能使用一行代码。

编程方法论:面向过程、函数式、面向对象

函数式编程:编程语言定义的函数 + 数学意义的函数

函数是Python内建支持的一种封装,我们通过把大段代码拆成函数,通过一层一层的函数调用,就可以把复杂任务分解成简单的任务,这种分解可以称之为面向过程的程序设计。函数就是面向过程的程序设计的基本单元。

而函数式编程(请注意多了一个“式”字)——Functional Programming,虽然也可以归结到面向过程的程序设计,但其思想更接近数学计算。

我们首先要搞明白计算机(Computer)和计算(Compute)的概念。

在计算机的层次上,CPU执行的是加减乘除的指令代码,以及各种条件判断和跳转指令,所以,汇编语言是最贴近计算机的语言。

而计算则指数学意义上的计算,越是抽象的计算,离计算机硬件越远。

对应到编程语言,就是越低级的语言,越贴近计算机,抽象程度低,执行效率高,比如C语言;越高级的语言,越贴近计算,抽象程度高,执行效率低,比如Lisp语言。

函数式编程就是一种抽象程度很高的编程范式,纯粹的函数式编程语言编写的函数没有变量,因此,任意一个函数,只要输入是确定的,输出就是确定的,这种纯函数我们称之为没有副作用。而允许使用变量的程序设计语言,由于函数内部的变量状态不确定,同样的输入,可能得到不同的输出,因此,这种函数是有副作用的。

函数式编程的一个特点就是,允许把函数本身作为参数传入另一个函数,还允许返回一个函数!

Python对函数式编程提供部分支持。由于Python允许使用变量,因此,Python不是纯函数式编程语言。

高阶函数:满足1.函数接受的参数是一个函数名 2.返回值中包含函数

#返回值中包含函数
def foo():
print('from foo')
return bar
def bar():
print('from bar') n = foo()
n()
def handle():
print('from handle')
return handle()
handle()
======================
from foo
from bar
from handle

函数尾调用:在函数最后一步调用另外一个函数(最后一行不一定是函数的最后一步)

def test(x):
if x > 1:
return True
elif x == 1:
return False
else:
return True
n = input('please a number')
print(test(int(n,10))) #尾调用示例 True
  • map函数依次处理每个列表元素
  • filter函数依次筛选列表的每一个值,最后得一个列表
  • reduce函数把两个完整的序列压缩到一起

map函数

注意
num_l = [1,2,3,4,5,6]
def add_one(x):
return x+1
def reduce_one(x):
return x-1
def pf(x):
return x**2
def map_test(func,array): ret = []
for i in num_l:
res = add_one(i)
ret.append(res)
return ret
print(map_test(reduce_one,num_l)) #终极版本
def map_test(func,array):
ret=[]
for i in num_l:
res=func(i)
ret.append(res)
return ret print(map_test(lambda x:x+1,num_l)) map内置高级函数用法
num_l=[1,2,3,4,5]
print(list(map(lambda x:x+1,num_l)))
msg='linhalifneg'
print(set(map(lambda x:x.upper(),msg)))


filter函数

#过滤函数的功能
movie_people = ['alex','wupe_sb','xsss_sb','sql_sb'] def sb_show(n):
return n.endswith('sb')
def filter_test(func,array):
ret = []
for p in array:
if not func(p):
ret.append(p)
return ret
res = filter_test(sb_show,movie_people)
print(res) #filter函数格式:filter(过滤方法,可迭代变量)
#过滤方法可以是匿名函数
movie_people = ['alex','wupe_sb','xsss_sb','sql_sb'] res = filter(lambda n:not n.endswith("_sb"),movie_people)
print(list(res)) =======>>['alex']

reduce函数

from functools import reduce 从此模块中导入reduce函数

#可以起到reduce作用
num_l=[1,2,3,100]
def reduce_test(array):
res=0
for num in array:
res+=num
return res
print(reduce_test(num_l))
#终极版的reduce功能
numl=[1,2,3,100] lambda x,y:x*y,numl
def multi(x,y):
return x*y num_l=[1,2,3,100] def reduce_test(func,array):
res=array.pop(0) #取出第一个值,以便进行下面运算
for num in array:
res=func(res,num)
return res
print(reduce_test(lambda x,y:x*y,num_l)) #指定起始值,在进行运算 注意:init不是替代第一个而是被添加到第一个
num_l=[1,2,3,100] def reduce_test(func,array,init=100):
if init is None:
res=array.pop(0)
else:
res=init
for num in array:
res=func(res,num)
return res print(reduce_test(lambda x,y:x*y,num_l)) #reduce函数 注意:reduce(某功能函数,可迭代变量,起始值)
from functools import reduce
num_l=[1,2,3,100]
print(reduce(lambda x,y:x*y,num_l,2))

 内置函数

bool()    #转换为布尔值   空,None,0为假值
int() #转换为整型
float() #转换为浮点型数据
len() #测试字符串长度或者统计可迭代对象的元素个数
list() #转换为列表
tulple() #转换为元组
dict() #转换为字典
set() #转换为集合
str() #转换为字符串型
例如:dic={'name':'alex'}
dic_str=str(dic) ===》‘{‘name’:‘Alex’}’ hex() #十进制转16进制
oct() #十进制转8进制
id() #打印对象的内存地址
input() #输入字符
isinstance() #判断值与类型是否一致 globals() #打印全局变量
locals() #打印局部变量 abs() #绝对值函数
all() #若一个为假即为假,全真即为真 注意只能有一个参数,可以是列表
any() #任意一个为真即为真
chr() # 把ASCII码值转为对应的字符 chr(97) ====>>A
ord() #与chr()正好相反,通过字符转换为ASCII码值
pow(x,y) #x的y次幂,若是3个参数则对第三个进行取余运算。
round(3.5)#四舍五入函数,===》4
reversed()#反转序列,前面加上个可迭代对象才能看出来
sorted() #排序,默认升序,注意:;不同类型不能排序 max() #取最大值 ha=[1,2,199,-1] max(ha)===>>199
min() #取最小值
age_dic = {'age1':18,'age2':81,'age3':11,'age4':28,'age5':180}
print(max(age_dic.values()))
#不同类型不能进行比较,字典不能比较,因为它是无序的
l=['a10','b12',100]
print(list(max(l))) #拉链函数,产生生一个内存对象,可利用列表、元组等可迭代对象进行输出,注意一一对应输出
zip(('a','b','c'),(1,2,3)) =======》[('a',1),('b',2),('c',3),]
例如:若要使字典中key与value一一对应
p={'name':'alex','age':18,'gender':'none'}
print(list(zip(p.keys(),p.values())))
===>>[('name', 'alex'), ('age', 18), ('gender', 'none')]
dir(byte('我是gbk编码',encoading='gbk'))  #打印某一对象中有哪些属性与方法
help() #打印帮助信息,用于查看函数是干什么的

slice(初始,结束,步长) #定义切片,可读性好
li='hello'
s = slice(2,5,2)) ====>lo
s.start s.stop s.step =====>> 2 5 2 frozenset() #返回一个冻结的可迭代对象,冻结后序列不能再添加或删除任何元素 divmod(10,3)==>(3,1) #多用于分页,结果左侧表示一共多少页,右侧表示剩下多少条记录
eval() #1.提取出字符串中的数据结构, 2.把字符串表达式进行运算
express='1+2*(3/3-1)-2'
print(eval(express)) ====》-1.0 #把字符串转换为字节形式,必须进行编码,也可以进行解码。注意:utf-8编码使一个字符等于3个字节,gbk 一个字符等于两个字节,ASCII码不能编码中文
bytes('你好',encoading="utf-8") #解码:用什么编码就用什么解码 默认解码是gbk
bytes('hello,boy!',encoading='utf-8').decode('utf-8') hash() #进行哈希运算,可哈希的数据类型即不可变数据类型,不可变哈希类型即可变数据类型。不管输入数据多大,哈希值都定长,不可根据哈希值逆推回字符串。注意:哈希可用于判定软件木马,当下载一个软件包时产生一个哈希值,当安装时又产生一个,两个相互对比可判断是否被添加了木马或其他信息。

max、min函数高级用法

1.max函数处理的是可迭代对象,相当于一个for循环去除每个元素进行比较,注意:不同类型之间不能进行比较
2.每个元素间进行比较,都是从第一个位置依次比较。
people=[
{'name':'王八','age':1000},
{'name':'龟','age':10000},
{'name':'九千岁','age':9000},
{'name':'alex','age':18}
] print(max(people,key=lambda dic:dic['age'])) ret=[]
for item in people:
ret.append(item['age'])
print(ret)
max(ret)
sum函数:求和函数   例如:sum(range(5)) sum(可迭代对象)
locals()  打印局部变量,以字典形式
vars([object]) 返回是字典形式,若没有参数相当于locals()函数,若有参数(str、int。。。)则将其所以方法存入字典形式 _import_() 导入模块,模块就是py文件
#test.py
def sya_hi():
  print('hello,handsome young man!')

import test
tst.say_hi()

_import_('test')  #按字符串样式导入模块
import() #不能调用字符类型模块