六个Python编程最受用的内置函数使用详解
作者:Sir 发布时间:2022-06-12 22:26:01
在日常的python编程中使用这几个函数来简化我们的编程工作,经常使用能使编程效率大大地提高。
1. Map 函数
map函数可以使用另外一个函数转换整个可迭代对象的函数,包括将字符串转换为数字、数字的四舍五入等等。
之所以使用map函数来完成这些事情可以节约内存,使代码的运行速度提高,并且使用的代码量比较少。
比如这里需要将一个字符串的数组转换成数字的数组的形式。
使用传统的方式来进行解析的话,使用for循环的方式就需要好几行的代码才能完成。
strings = ['1', '2', '3', '4']
res = []
for str_ in strings:
res.append(int(str_))
print(res)
# [1, 2, 3, 4]
使用map函数直接需要一行代码就可以完成了。
strings = ['5', '6', '7', '8']
res_map = map(int, strings)
print(list(res_map))
# [5, 6, 7, 8]
使用map(int,strings),其中int是作为函数作为参数传入的,而strings就是可以迭代的对象。
这里再使用一个我们自己创建的函数来转换可序列化的数据。
初始化一个make_super函数用来将英文字符串转换成'大写'的字符串。
def make_super(text):
res_text = text.upper()
return res_text
words = ['python', 'java', 'scala']
words_res = list(map(make_super, words))
print(words_res)
# ['PYTHON', 'JAVA', 'SCALA']
使用map(make_super, words),其中make_super是作为函数传入的,而words作为可序列化数据。
2. Lamdba 函数
lambda 函数用于创建匿名函数,又被称为lambda表达式。实际上它只是一个表达式的存在,如果在代码编写过程中需要实现简单的函数逻辑但是单独写一个函数又比较麻烦就可以使用lambda表达式只需要一行代码就可以完成了。
比如需要实现一个简单的加法计算,使用基本的函数来实现需要创建一个add_1函数。
def add_1(a, b):
return a + b
print(add_1(5, 2))
而使用lambda表达式,一行代码就可以直接完成了,可以像下面这样写。
add_2 = lambda a, b: a + b
print(add_2(10, 10))
lambda a,b: a + b 表示a,b是作为参数,a + b是作为函数的运算逻辑被执行。
3. Enumerate 函数
enumerate 函数一般用于可序列化数据的处理上面,而python中的可序列化数据又比较多,重要性就可想而知了。
可以使用该函数直接遍历出一个可序列化数据的下标索引以及对应的数据。
使用一个列表数据来进行举例说明。
words = ['java', 'python', 'scala']
使用enumerate函数来执行一下整个遍历,最终返回一个新的列表。
for index, data in enumerate(words):
print(f'当前索引:{index},当前数据:{data}')
# 当前索引:0,当前数据:java
# 当前索引:1,当前数据:python
# 当前索引:2,当前数据:scala
看到返回的结果中包含了索引、数据,这样便于数据的组织和统计,因此,将该函数也列为比较常用的函数之一。
4. Reduce 函数
reduce函数通常用于计算整个列表的逻辑运算,也就是将一个函数的运算可以添加到这个列表的每个元素上面。
'''
reduce(function, iterable[, initializer])
'''
比如需要计算一个列表中每个元素之间的相乘的结果,则可以这样写。
from functools import reduce
list_ = [10, 20, 30, 40]
print(reduce(lambda a, b: a * b, list_))
这里由于函数的逻辑运算比较简单,所以使用了lambda表达式表示两个元素相乘。
最终再使用reduce函数,它的效果相当于10 * 20 * 30 * 40,结果就是240000,和我们预想得到的计算结果是一致的。
5. Filter 函数
filter函数,从字面意思就可以看出它是过滤的意思,使用该函数可以有效的过滤掉不需要的列表中的数据元素。
'''
filter(function, iterable)
'''
在逻辑处理中,同样是需要一个处理函数和一个可序列化的数据。
nums = [1, 2, 3, 4, 5, 6, 7, 8, 9, 20]
nums_new = filter(lambda m: m % 2 == 0, nums)
print(list(nums_new))
# [2, 4, 6, 8, 20]
这里我们成功过滤掉了所有的奇数数据元素,最终只留下了偶数元素。
6. Zip 函数
zip函数在多个列表的组装过程中用到非常的多,可以同时遍历多个列表并将相同位置的元素组合成一个元祖。
list_res = []
for n in zip([1, 2, 3, 4, 5], ['python', 'java', 'scala', 'c++', 'C#']):
list_res.append(n)
print(list_res)
# [(1, 'python'), (2, 'java'), (3, 'scala'), (4, 'c++'), (5, 'C#')]
使用zip函数时,像这样的数据组合就可以轻松的实现。
通过观察上述的这些操作发现基本上都是对可序列化的数据的相关操作,因为在python的编码过程中大多数的数据处理相关的操作都是基于可序列化的数据的。
来源:https://mp.weixin.qq.com/s/OfWtT44ZFgZg2REZLyp7iA


猜你喜欢
- 1、关于 StatsModelsstatsmodels(http://www.statsmodels.org)是一个Python库,用于拟合
- 访问phpmyadmin时总是出现 “无法载入 mysql 扩展,请检查 PHP 配置”。
- 运用Jmeter正则提取器,可以从请求的响应结果中取到需要的内容,从而实现关联。关联是请求与请求之间存在数据依赖关系,需要从上一个请求获取下
- 最近出的每日一题里面,有一道是关于合并同类型数据为一行的题,使用SQL Server 2017版本及以上的直接使用STRING_AGG()函
- 关于数据库的逻辑设计,是一个很广泛的问题。本文主要针对开发应用中遇到在MS SQL Server上进行表设计时,对表的主键设计应注意的问题以
- 创建项目和应用django-admin startproject zqxt_views(项目名)cd zqxt_viewspython ma
- 目录1 作用2 安装3 所有要运行的命令都放在 manager.py 中4 三种方式 创建命令4.1 方式一 创建 Command子类4.2
- 类型1:父类和子类的实例变量均不需要传递class A(object): def __init__(self):
- 对于值传递和引用传递,书本上的解释比较繁琐,而php面试中总会出现,下面我会通过一个生活的例子带大家理解它们之间区别。第一步假设我们去酒店订
- 简而言之,channel维护了一个带指针的接受和发送的队列,其中包含mutex锁保证并发安全,数据类型,元素个数,元素大小,channel状
- 首先要做的就是去豆瓣网找对应的接口,这里就不赘述了,谷歌浏览器抓包即可,然后要做的就是分析返回的json数据的结构:https://movi
- 本人初学python是菜鸟级,写的不好勿喷。python爬虫用了比较简单的urllib.parse和requests,把爬来的数据显示在地图
- 封装数据库操作,并且提供事务处理。 使用DbProviderFactories的数据库操作类 Imports System.Data Imp
- 完整代码下载:http://xiazai.jb51.net/201407/tools/python-migong.rar最近研究了下迷宫的生
- 本文实例讲述了php函数serialize()与unserialize()用法。分享给大家供大家参考。具体方法如下:该实例主要讲述了php函
- 通常,在完成了一件网页设计后,设计师的无知都会显露无遗而备受指责。他们把创建网页代码的繁重工作都留给了程序员们。这种现象不只出现在网络开发行
- logging是python语言中的一个日志模块,专门用来写日志的,日志级别通常分为debug、info、warning、error、cri
- 目录背景实现工具打包调用总结众所周知,Golang 适合写 CLI 工具,但你可能还不知道 Golang 还可以打包配置文件。背景最近在写一
- 爬一个网页时,要保存的数据都没有encode,就导致保存下来的中文都变成unicode了。。。那么,怎么把一个表示字符串的unicode还原
- 原始两张图片:代码运行结果如下。5种算法值哈希算法、差值哈希算法和感知哈希算法都是值越小,相似度越高,取值为0-64,即汉明距离中,64位的