python入门之函数结构第三关,python3高级编程
本文主要详细介绍Python3的高阶函数,主要介绍什么是高阶函数,高阶函数的用法以及几种常见的内置高阶函数。有一定的参考价值,感兴趣的朋友可以参考一下。
00-1010 1.高阶函数2.map/reduce3.filter4.sorted综述
目录
# 1.变量指向函数
#调用函数和函数本身
print(-10的绝对值是:,abs(-10))
Print(绝对值函数本身:,abs)
打印(-)
#将函数调用结果和函数本身赋给变量,即变量指向函数。
abs1=abs(-100)
打印(-100的绝对值为:,abs1)
selfAbs=abs
打印( abs函数本身:,selfAbs)
打印(-)
# 2.函数名也是变量
#函数名:指向函数的变量;
#可以将abs指向-10,即:abs=-10
# 3.传入函数:一个函数可以接收另一个函数作为自变量,称为高阶函数;
#示例:
def add(x,y,f):
返回f(x) f(y)
#调用add()函数
print(add(-5,-10,abs))的值为:,add(-5,-10,abs))
#结果输出:
-10的绝对值是:10
函数本身的绝对值:内置函数abs
-
-100的绝对值是:100
abs函数本身:内置函数abs
-
add(-5,-10,abs)的值为:15
1.高阶函数
#减少
# reduce对序列[x1,x2,].这个函数必须接收两个参数;
# reduce继续计算结果,并对序列的下一个元素进行累积计算;
# reduce(f,[x1,x2,x3,x4])=f(f(f(x1,x2),x3),x4)
#示例:
从functools导入减少
def add(x,y):
返回x y
numsList=[1,3,5,7,9]
print( reduce 作用于numlist的结果是:,reduce(add,numlist))
打印(-)
#计算1-10的阶乘
def mul(x,y):
返回x * y
numsList=list(范围(1,11))
Print(使用reduce函数计算1-10的阶乘:,reduce(mul,numsList))
#结果输出:
numsList上reduce的结果是:25
-
使用reduce函数计算1-10的阶乘:3628800
#减少
# reduce对序列[x1,x2,].这个函数必须接收两个参数;
# reduce继续计算结果,并对序列的下一个元素进行累积计算;
# reduce(f,[x1,x2,x3,x4])=f(f(f(x1,x2),x3),x4)
#示例:
从functools导入减少
def add(x,y):
返回x y
numsList=[1,3,5,7,9]
print( reduce 作用于numlist的结果是:,reduce(add,numlist))
打印(-)
#计算1-10的阶乘
定义管理部门
l(x,y):
return x * y
numsList = list(range(1,11))
print("使用reduce函数计算1-10的阶乘:",reduce(mul,numsList))
# 结果输出:
"""
reduce作用于numsList的结果为: 25
-------------------------------------------------------------
使用reduce函数计算1-10的阶乘: 3628800
"""
3.filter
def is_odd(n):return n % 2 == 1
# 在list中删除偶数,保留奇数
numsList = [1,2,5,7,19,23,3,6,9]
print("numsList内容为:",numsList)
print("filter后的结果:",list(filter(is_odd,numsList)))
print("--------------------------------------------------")
# 用埃氏筛法求素数
# 1.构造一个从3开始的奇数序列
def _odd_iter():
n = 1
while True:
n = n + 2
yield n
# 2.定义一个筛选函数
def _not_divisible(n):
return lambda x: x % n > 0
# 3.定义一个生成器,不断返回下一个素数
def primes():
yield 2
it = _odd_iter() # 初始序列
while True:
n = next(it) # 返回序列的第一个数
yield n
it = filter(_not_divisible(n), it) # 构造新序列
# 打印1000以内的素数
for n in primes():
if n < 1000:
print(n,end = " ")
else:
break
# 结果输出:
numsList内容为: [1, 2, 5, 7, 19, 23, 3, 6, 9]
filter后的结果: [1, 5, 7, 19, 23, 3, 9]
--------------------------------------------------
2 3 5 7 11 13 17 19 23 29 31 37 41 43 47 53 59 61 67 71 73 79 83 89 97 101 103 107 109 113 127 131 137 139 149 151 157 163 167 173 179 181 191 193 197 199 211 223 227 229 233 239 241 251 257 263 269 271 277 281 283 293 307 311 313 317 331 337 347 349 353 359 367 373 379 383 389 397 401 409 419 421 431 433 439 443 449 457 461 463 467 479 487 491 499 503 509 521 523 541 547 557 563 569 571 577 587 593 599 601 607 613 617 619 631 641 643 647 653 659 661 673 677 683 691 701 709 719 727 733 739 743 751 757 761 769 773 787 797 809 811 821 823 827 829 839 853 857 859 863 877 881 883 887 907 911 919 929 937 941 947 953 967 971 977 983 991 997
4.sorted
# 排序算法# sorted()函数可以对list进行排序;
numsList = [1,2,4,3,9,6,8,7,0]
print("原始的list内容:",numsList)
print("使用sorted排序后list内容:",sorted(numsList))
print("----------------------------------------------------------")
# sorted()函数可以接收一个key函数来实现自定义排序
# 按绝对值大小排序
numsList2 = [-10,2,3,4,6,5,-9,-8,7]
print("原始的list内容:",numsList2)
print("按照绝对值排序:",sorted(numsList2,key = abs))
print("----------------------------------------------------------")
# 忽略大小写对字符串列表进行排序
nameList = ["Willard","ChenJD","ChenBao","ChenXiaoBao","hackerLuo"]
print("nameList原始内容为:",nameList)
print("忽略大小写排序:",sorted(nameList,key = str.lower))
print("对列表反向排序:",sorted(nameList,key = str.lower,reverse = True))
# 结果输出:
原始的list内容: [1, 2, 4, 3, 9, 6, 8, 7, 0]
使用sorted排序后list内容: [0, 1, 2, 3, 4, 6, 7, 8, 9]
----------------------------------------------------------
原始的list内容: [-10, 2, 3, 4, 6, 5, -9, -8, 7]
按照绝对值排序: [2, 3, 4, 5, 6, 7, -8, -9, -10]
----------------------------------------------------------
nameList原始内容为: ['Willard', 'ChenJD', 'ChenBao', 'ChenXiaoBao', 'hackerLuo']
忽略大小写排序: ['ChenBao', 'ChenJD', 'ChenXiaoBao', 'hackerLuo', 'Willard']
对列表反向排序: ['Willard', 'hackerLuo', 'ChenXiaoBao', 'ChenJD', 'ChenBao']
总结
本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注盛行IT软件开发工作室的更多内容!
郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。