• 1
  • 0
分享
  • Python3,这应该是,使用最广泛的6个内置函数,别说你还不知道。
  • Carl_奕然 2022-11-24 12:11:17 字数 3633 阅读 1102 收藏 0

1、引言

小屌丝:鱼哥, 都说要想代码写的溜,Lamdba不能少。

小鱼:你在项目代码多写几个lamdba试试,看看架构师找不找你喝茶水。

小屌丝:…

小鱼:逗你玩… 架构师哪舍得自己花钱买茶叶,都是能蹭就蹭…

小屌丝:…

小鱼:你这突然提到lamdba函数,是想了解点什么??

小屌丝:嘿嘿,真是什么都瞒不过你, 我就想把python最常用的内置函数在重新捋一捋,

小鱼:说实话。

小屌丝:你也知道,我女神最近在学习python,所以我想…

小鱼:靠… 就知道你是这样的!

小屌丝:鱼哥,我也是身不由己啊, 不然… 说出来都是眼泪。

小鱼:行了,别装的这么可怜, 我给你捋一捋不就行了。

小屌丝:啥也别说了,此时我想…

2、内置函数详解

2.1 Lamdba 函数

lambda 函数用于创建匿名函数,又被称为lambda表达式。

实际上它只是一个表达式的存在,如果在代码编写过程中需要实现简单的函数逻辑但是单独写一个函数又比较麻烦就可以使用lambda表达式只需要一行代码就可以完成了。

比如需要实现一个简单的加法计算,使用基本的函数来实现需要创建一个add_1函数。

示例:

实现一个简单的加法计算。

一、基本函数

代码示例

# -*- coding:utf-8 -*-
# @Time   : 2022-08-24
# @Author : Carl_DJ
#基本函数来实现加法计算
def add_ms(x,y):
    return x + y
print(f'输出结果:{add_ms(8,9)}')

运行结果

输出结果:17

二、lamdba表达式

使用lamdba表达式来实现

代码示例

# -*- coding:utf-8 -*-
# @Time   : 2022-08-24
# @Author : Carl_DJ
#lamdba表达式来实现
add_lamd = lambda x,y:x+y
print(f'lamdba表达式输出结果:{add_lamd(5,10)}')

运行结果

lamdba表达式输出结果:15

解析:

    lambda x,y: x + y 表示 x,y是作为参数,x + y是作为函数的运算逻辑被执行。

2.2 Map 函数

map函数可以使用另外一个函数转换整个可迭代对象的函数,包括将字符串转换为数字、数字的四舍五入等等。

之所以使用map函数来完成这些事情可以节约内存,使代码的运行速度提高,并且使用的代码量比较少。

2.2.1 数字转换

示例:

将一个字符串的数组转换成数字的数组的形式,这里用两种方式:

    ①传统的for循环方式

    ②map函数

接下来,我们用代码转换。

一、传统for循环方式

代码示例

# -*- coding:utf-8 -*-
# @Time   : 2022-08-24
# @Author : Carl_DJ
#for 循环来读取res列表的值
strings = ['10','20','30','40','50']
res = []
for str in strings:
    res.append(int(str))
print(f'输出结果:{res}')

运行结果

输出结果:[10, 20, 30, 40, 50]

二、map函数

我们使用map函数方式来转换。

代码示例

# -*- coding:utf-8 -*-
# @Time   : 2022-08-24
# @Author : Carl_DJ
#调用map函数
strings = ['11','22','33','44','55']
res_map = map(int,strings)
print(f'map函数输出结果:{list(res_map)}')

运行结果

map函数输出结果:[11, 22, 33, 44, 55]

可以看到,map函数,一行代码就可以转换完成,非常方便。

2.2.2 字母大小写转换

解析:

    map(int,strings),其中int是作为函数作为参数传入的,而strings就是可以迭代的对象。

示例

    把小写英文字母转换成大写英文字母

代码示例

# -*- coding:utf-8 -*-
# @Time   : 2022-08-24
# @Author : Carl_DJ
'''
代码实现功能:
创建函数,来转换可转化的序列数据
初始化make_super函数,将小写英文转换成大写英文
'''
#定义make_super函数,
def make_super(text):
    res_text = text.upper()
    return res_text
#定义英文单词列表
words = ['python', 'java', 'ruby','go']
#转化
words_res = list(map(make_super, words))
print(f'转换结果:{words_res}')

运行结果

转换结果:['PYTHON', 'JAVA', 'RUBY', 'GO']

使用map(make_super, words),其中make_super是作为函数传入的,而words作为可序列化数据。

2.3 Filter 函数

定义

    filter函数:使用该函数可以有效的过滤掉不需要的列表中的数据元素。

方法

'''
filter(function, iterable)
'''

代码示例

在逻辑处理中,同样是需要一个处理函数和一个可序列化的数据。

# -*- coding:utf-8 -*-
# @Time   : 2022-08-24
# @Author : Carl_DJ
#定义列表
list_num = [11,22,33,44,55,66,77]
#过滤掉偶数,保留奇数
new_list = filter(lambda n:n % 2 == 1,list_num)
print(f'过滤后的结果:{list(new_list)}')

运行结果

过滤后的结果:[11, 33, 55, 77]

通过运行结果,可以看到过滤掉了所有的偶数元素,留下了奇数元素。

2.4 Reduce 函数

定义

    reduce函数通常用于计算整个列表的逻辑运算,即将一个函数的运算可以添加到这个列表的每个元素上面。

方法

'''
reduce(function, iterable[, initializer])
'''

代码示例

计算一个列表中每个元素之间的相乘的结果:

# -*- coding:utf-8 -*-
# @Time   : 2022-08-24
# @Author : Carl_DJ
from functools import reduce
#列表
list_re = [10,20,30,40,50,]
#计算每个元素的乘积
print(f'计算结果:{reduce(lambda x, y: x * y, list_re)}')

运行结果

计算结果:12000000

2.5 Enumerate 函数

定义

    enumerate 函数:一般用于可序列化数据的处理上面,而python中的可序列化数据又比较多,所以,还是蛮重要的。

代码示例

可以使用该函数直接遍历出一个可序列化数据的下标索引以及对应的数据。

# -*- coding:utf-8 -*-
# @Time   : 2022-08-24
# @Author : Carl_DJ
#定义列表内容
words = ['python', 'java', 'ruby','go']
#遍历执行,返回新的列表
for index, data in enumerate(words):
    print(f'当前索引:{index},当前数据:{data}')

运行结果

当前索引:0,当前数据:python
当前索引:1,当前数据:java
当前索引:2,当前数据:ruby
当前索引:3,当前数据:go

2.6 Zip 函数

定义

    zip函数:可以同时遍历多个列表并将相同位置的元素组合成一个元祖。

代码示例

#定义空列表
list_res = []
#遍历列表使其相同位置元素能组合成
for m in zip([1, 2, 3, 4, 5], ['python', 'java', 'ruby', 'go', 'C#']):
    list_res.append(m)
print(f'输出结果:{list_res}')

运行结果

输出结果:[(1, 'python'), (2, 'java'), (3, 'ruby'), (4, 'go'), (5, 'C#')]

3、总结

看到这里,今天的分享差不多就完事了。

今天共分享了六种常用的内置函数:

    Lamdba 函数

    Map 函数

    Filter 函数

    Reduce 函数

    Enumerate 函数

    Zip 函数

在实际的工作中,这些都是非常实实在在常用的函数,

所以,这些也都是必须要掌握的知识。


我是奕然:

关注我,带你学习更多更有趣的Python知识。


  • 【留下美好印记】
    赞赏支持
登录 后发表评论
+ 关注

热门文章

    最新讲堂

      • 推荐阅读
      • 换一换
          • 在测试行业,一个一直被讨论的问题就是:手工测试没有前途,自动化测试会取代手工测试?首先说结论:自动化测试不会取代手工测试,这完全是两个维度的事情。为什么不会呢?我们需要从本源上说起。手工测试没有前途,自动化测试会取代手工测试吗?什么是自动化世界上有很多职业,比如艺术家、维修人员、销售等等,每种职业都需要人来参与,而每种职业也都有部分工作交给机器来做。但无论哪种职业,几乎都是人来主导,然后将越来越多的工作交给机器来做,而机器无法实现的工作,比如创新、情感、思维等,只能由每个具体的人来完成。而这些必须由具体的人来完成的事情,我们称之为“手工”,机器完成的部分,我们称之为“自动化”。因此,手工、自动...
            0 0 820
            分享
          • 7 月 29 日晚,Dify 主创团队如约与社区朋友们线上直面交流,由 Dify 的数据集产品&架构负责人姜勇(Jyong)给大家分享在企业知识库嵌入 AI ChatBot 应用中最核心的 Embedding 技术概念和 Dify 数据集的设计和规划。我们还整理了本次会议中用户关心的问题,供大家阅读参考。Embedding 技术的文本向量化"Embedding"是一种将离散型变量(如单词、句子或者整个文档)转化为连续的向量表示的技术。这个向量表示(Embedding)可以捕捉到离散型变量间的相似性和关系。这段话听起来很晦涩,但其实它的本质是特征性的收集,将事物所有的...
            0 0 1796
            分享
          •   据报道,针对美国政府起诉微软690亿美元收购动视暴雪交易,法官将于1月3日举行首次审前听证会。  去年1月,微软宣布将以每股95美元的现金,收购游戏开发和互动娱乐内容发行商动视暴雪,交易总金额约为690亿美元。交易完成后,微软将成为世界上营收第三高的游戏公司,仅次于腾讯和索尼。  上个月,负责反垄断执法的美国联邦贸易委员会(FTC)要求法官阻止这笔交易,理由是交易将使微软的Xbox游戏平台获得动视暴的独家内容,从而导致竞争对手任天堂和索尼的游戏平台被冷落。  而微软则反驳称,这笔交易将使游戏玩家和其他游戏公司从中受益。同时,微软还承诺,至少在10年内继续向索尼等竞争对手提供《使命召唤》游戏...
            0 0 988
            分享
          •   25岁一般来说也就是本科或专科毕业3年左右,有过一定的工作经验和阅历,同时还保留一部分棱角。25岁只能说是你人生刚起步,之所以会有这个年龄层面的顾虑就是因为各种互联网报道到处鼓吹35岁危机,其实在哪一行都会有危机,如何平稳度过这些所谓的危机,关键点在于你是否具有相关的核心竞争力。  这些报道数不胜数,比如某某高速路收费工作人员,当信息化时代来临被迫下岗时,只能无言的对着镜头说我今年36岁了,除了收费啥也不会,而且也学不会了!,这就属于典型的没有核心竞争力,正如央视主持人张泉灵所说:安逸的生活已经不再适合这个高速进步的时代,当时代抛弃你时,连一声再见都不会说的!  在25岁的年龄,能意识到行...
            0 0 333
            分享
          •   应用场景  开始了解stf主要源自于当前移动端自动化过程中,发现执行机器上挂载的移动设备监控起来比较麻烦,有时候报错或调试需要跑到执行机所在的位置查看运行情况。  有没有一种办法可以直接在自己位置上就能看到手机的运行情况呢?于是就在领导的指引下调研了一下该工具。  但其实这款工具还可以帮助解决公司内部移动设备资源不能充分利用的问题,如:  公司移动设备其实是有限的,有的人借走了用完未及时归还,导致其他人就无法使用,而使用这款工具就可以统一监控公司的所有移动设备资源,使用者可在浏览器界面上查看哪些设备是空闲状态,在页面上就可以操作对应设备。  本文案例环境配置  windows上通过VMwa...
            11 11 1443
            分享
      • 51testing软件测试圈微信