16-Python高阶函数-效率翻倍
发布日期:2021-06-29 17:32:42 浏览次数:2 分类:技术文章

本文共 4471 字,大约阅读时间需要 14 分钟。

python中有许多内置函数,不像print那么广为人知,但它们却异常的强大,用好了可以大大提高代码效率。

一、编程的3种方法:

•面向过程:将一个大问题分成若干个小问题进行逐一的处理•函数式编程:是将编程语言的函数和数学意义的函数相结合,如y=2*x+1相当于

def func(x):    return 2 * x + 1

•面向对象:将事物的本质通过建立一系列模型来体现出事物的本质和特征

二、高阶函数:

1、高阶函数的定义:

•函数接收的参数可以是另一个函数的函数名•在函数的返回值中包含于一个函数名

2、3个常用的内置高阶函数:

2.1:map()函数:

•将列表[1, 2, 3, 4]中的每个元素进行加10

方法1:

list01 = [1, 2, 3, 4]def func(x):    return x + 10def add_num(function, array):    res = []    for i in array:        res.append(function(i))    return resprint(add_num(func, list01))

方法2:

list01 = [1, 2, 3, 4]def add_num(function, array):    res = []    for i in array:        res.append(function(i))    return resprint(add_num(lambda x:x+10, list01))

使用map()函数:

list01 = [1, 2, 3, 4]print(list(map(lambda x:x+10, list01)))

运行结果:

[11, 12, 13, 14]

map()函数的用法: map(处理方法, 可迭代对象)

功能: 对可迭代对象中的每个元素按照指定的处理方法进行操作,最后以迭代类型输出,可将其转换为相应的数据类型进行输出

2.2:filter()函数:

•将列表[{"class":101, "name":"zhang"},{"class":102, "name":"li"},{"class":201, "name":"wang"},{"class":202, "name":"zhao"}]中的年级是一年级的删除

方法1:

def func(x):    return x["class"][0]def class_list(function, array):    new_list = []    for i in array:        if function(i) != "1":            new_list.append(i)    return new_listprint(class_list(func, student_list))

方法2:

def class_list(function, array):    new_list = []    for i in array:        if function(i) != "1":            new_list.append(i)    return new_listprint(class_list(lambda x:x["class"][0], student_list))

filter()方法:

print(list(filter(lambda x:x["class"][0] != "1", student_list)))

运行结果:

[{'class': '201', 'name': 'wang'}, {'class': '202', 'name': 'zhao'}]

filter()函数的用法: filter(处理方法, 可迭代对象)

“处理方法”得到的结果必须是一个布尔值

功能: 将可迭代对象中的元素按照指定的处理方法进行删选后以迭代类型输出,可将其转换为相应的数据类型进行输出

2.3:reduce()函数:

在Python2中可直接使用reduce()函数,在Python3中需要导入functools模块后才能使用。

•将列表[2, 3, 4, 10]中的元素跟指定的初始值(可选)累乘后进行输出

方法1:情况1:没有指定初始值

def func(x, y):    return x * ydef times(function, array, init=None):    if init == None:        res = 1    else:        res = init    for num in array:        res = function(res, num)        # res *= num    return resprint(times(func, list01))

情况2:指定初始值

def func(x, y):    return x * ydef times(function, array, init=None):    if init == None:        res = 1    else:        res = init    for num in array:        res = function(res, num)        # res *= num    return resprint(times(func, list01, 100))

方法2:情况1:没有指定初始值

def times(function, array, init=None):    if init == None:        res = 1    else:        res = init    for num in array:        res = function(res, num)        # res *= num    return resprint(times(lambda x,y:x*y, list01))

情况2:指定初始值

def times(function, array, init=None):    if init == None:        res = 1    else:        res = init    for num in array:        res = function(res, num)        # res *= num    return resprint(times(lambda x,y:x*y, list01, 100))

reduce()方法:情况1:没有指定初始值

from functools import reduceprint(reduce(lambda x,y:x*y, list01))

情况2:指定初始值

from functools import reduceprint(reduce(lambda x,y:x*y, list01, 100))

reduce()函数用法: reduce(处理方法, 可迭代对象, 初始值)

功能: 将可迭代对象中的元素按照制定的处理方法进行运算后输出

set()

当需要对一个列表进行去重操作的时候,set()函数就派上用场了。

obj = ['a','b','c','b','a']print(set(obj))# 输出:{'b', 'c', 'a'}

set([iterable])用于创建一个集合,集合里的元素是无序且不重复的

集合对象创建后,还能使用并集、交集、差集功能。

A = set('hello')B = set('world')A.union(B) # 并集,输出:{'d', 'e', 'h', 'l', 'o', 'r', 'w'}A.interp(B) # 交集,输出:{'l', 'o'}A.difference(B) # 差集,输出:{'d', 'r', 'w'}

eval()

之前有人问如何用python写一个四则运算器,输入字符串公式,直接产生结果。

eval()来做就很简单:

eval(str_expression)作用是将字符串转换成表达式,并且执行。

a = eval('[1,2,3]')print(type(a))# 输出:
b = eval('max([2,4,5])')print(b)# 输出: 5

sorted()

在处理数据过程中,我们经常会用到排序操作,比如将列表、字典、元组里面的元素正/倒排序。

这时候就需要用到sorted() ,它可以对任何可迭代对象进行排序,并返回列表。

对列表升序操作:

a = sorted([2,4,3,7,1,9])print(a)# 输出:[1, 2, 3, 4, 7, 9]

对元组倒序操作:

sorted((4,1,9,6),reverse=True)print(a)# 输出:[9, 6, 4, 1]

使用参数:key,根据自定义规则,按字符串长度来排序:

chars = ['apple','watermelon','pear','banana']a = sorted(chars,key=lambda x:len(x))print(a)# 输出:['pear', 'apple', 'banana', 'watermelon']

根据自定义规则,对元组构成的列表进行排序:

tuple_list = [('A', 1,5), ('B', 3,2), ('C', 2,6)]# key=lambda x: x[1]中可以任意选定x中可选的位置进行排序a = sorted(tuple_list, key=lambda x: x[1]) print(a)# 输出:[('A', 1, 5), ('C', 2, 6), ('B', 3, 2)]

reversed()

如果需要对序列的元素进行反转操作,reversed()函数能帮到你。

reversed()接受一个序列,将序列里的元素反转,并最终返回迭代器。

a = reversed('abcde')print(list(a))# 输出:['e', 'd', 'c', 'b', 'a']b = reversed([2,3,4,5])print(list(b))# 输出:[5, 4, 3, 2]

唐_sri:https://www.jianshu.com/p/e2596e812bd5

《python小白入门系列教程》

IT入门 感谢关注

程序员题库→

程序员用的单词表→

练习地址:www.520mg.com/it

转载地址:https://cpython.blog.csdn.net/article/details/109302732 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:21-Python 装饰器
下一篇:11-python异常处理

发表评论

最新留言

关注你微信了!
[***.104.42.241]2024年04月22日 19时30分58秒