【Python基础篇012】匿名函数和全部内置函数详细认识(下篇)

简介: 【Python基础篇012】匿名函数和全部内置函数详细认识(下篇)

 目录

🏵️前言

🍁一、reversed内置函数

🍁二、slice内置函数

🍁三、format内置函数

🍁四、bytes内置函数

🍁五、bytearray内置函数

🍁六、memoryview内置函数

🍁七、ord、chr和ascii内置函数

🍁八、repr内置函数

🍁九、enumerate内置函数

🍁十、all和any内置函数

🍁十一、zip内置函数

🍁十二、filter和map内置函数

🔥1、filter内置函数

🔥2、map内置函数

🔥3、总结

🍁十三、sorted内置函数

🍁十四、匿名函数

🏵️结语


🏵️前言

👉以下我要讲解的是Python中最后剩余的重要内置函数,其中比较重要的会详细讲解,比较简单的会直接结合代码进行剖析

​编辑

🍁一、reversed内置函数

描述
reversed 函数返回一个反转的迭代器。

语法

reversed(seq)
参数
seq -- 要转换的序列,可以是 tuple, string, list 或 range。
返回值
返回一个反转的迭代器。

#使用reverse后原列表就不见了
l = [1,2,3,4,5]
l.reverse()
print(l)

#保留原列表,返回一个反向的迭代器
l = [1,2,3,4,5]
l2 =  reversed(l)
print(l2)

输出解果:
[5, 4, 3, 2, 1]
<list_reverseiterator object at 0x000001BF41858F40>

🍁二、slice内置函数

描述
slice() 函数实现切片对象,主要用在切片操作函数里的参数传递。

语法
slice 语法:

class slice(stop)
class slice(start, stop[, step])
参数说明:

start -- 起始位置
stop -- 结束位置
step -- 间距
返回值
返回一个切片对象。

l = (1,2,3,4,5,6)
#先得到了一个切片规则
sli = slice(1,5,2)
#按切片规则进行切分
print(l[sli])

输出结果:
(2, 4)

🍁三、format内置函数

知识点 http://t.csdn.cn/Onubp **

🍁四、bytes内置函数

描述
bytes 函数返回一个新的 bytes 对象,该对象是一个 0 <= x < 256 区间内的整数不可变序列。它是 bytearray 的不可变版本。

语法
以下是 bytes 的语法:

class bytes([source[, encoding[, errors]]])
参数
如果 source 为整数,则返回一个长度为 source 的初始化数组;
如果 source 为字符串,则按照指定的 encoding 将字符串转换为字节序列;
如果 source 为可迭代类型,则元素必须为[0 ,255] 中的整数;
如果 source 为与 buffer 接口一致的对象,则此对象也可以被用于初始化 bytearray。
如果没有输入任何参数,默认就是初始化数组为0个元素。
返回值
返回一个新的 bytes 对象。

注意:

网络编程只能传二进制

照片和视频也是以二进制存储

html网页爬取到的也是编码

#我拿到的是gbk编码的,我想转成utf-8编码
print(bytes('你好',encoding='gbk').decode('gbk'))
#unicode转换为utf-8的bytes
print(bytes('你好',encoding='utf-8'))

输出结果:
你好
b'\xe4\xbd\xa0\xe5\xa5\xbd'

🍁五、bytearray内置函数

描述
bytearray() 方法返回一个新字节数组。这个数组里的元素是可变的,并且每个元素的值范围: 0 <= x < 256。

语法
bytearray()方法语法:

class bytearray([source[, encoding[, errors]]])
参数
如果 source 为整数,则返回一个长度为 source 的初始化数组;
如果 source 为字符串,则按照指定的 encoding 将字符串转换为字节序列;
如果 source 为可迭代类型,则元素必须为[0 ,255] 中的整数;
如果 source 为与 buffer 接口一致的对象,则此对象也可以被用于初始化 bytearray。
如果没有输入任何参数,默认就是初始化数组为0个元素。
返回值
返回新字节数组。

b_array = bytearray('你好',encoding='utf-8')
print(b_array)
print(b_array[0])

输出结果:
bytearray(b'\xe4\xbd\xa0\xe5\xa5\xbd')
228

🍁六、memoryview内置函数

描述
memoryview() 函数返回给定参数的内存查看对象(memory view)。

所谓内存查看对象,是指对支持缓冲区协议的数据进行包装,在不需要复制对象基础上允许Python代码访问。

语法

memoryview(obj)
参数说明:

obj -- 对象
返回值
返回元组列表。
 

#切片 —— 字节类型的切片
v = memoryview(bytearray("abcd", 'utf-8'))
print(v[1])

输出结果:
98

🍁七、ord、chr和ascii内置函数

#ord     将字符按照unicode转数字
>>>print(ord('a'))
>>>print(ord('A'))
>>>print(ord('1'))
97
65
49


#chr     数字按照unicode转字符
>>>print(chr(65))
>>>print(chr(97))
A
a

#ascii   只要是ASCII码中的内容就打印出来,不是就转换为\u
#ascii   包括字母、数字、符号、拉丁文
>>>print(ascii('你好'))
>>>print(ascii(1))
>>>print(ascii("_12"))
>>>print(ascii('a'))
'\u4f60\u597d'
1
'_12'
'a'

🍁八、repr内置函数

描述
repr() 函数将对象转化为供解释器读取的形式。

语法
以下是 repr() 方法的语法:

**repr(object)
参数**
**object -- 对象。
返回值**
返回一个对象的 string 格式。

#可以判断控制台输出的数据是何类型
print(repr('1'))
print(repr(1))

输出结果:
'1'
1

🍁九、enumerate内置函数

描述
enumerate() 函数用于将一个可遍历的数据对象(如列表、元组或字符串)组合为一个索引序列,同时列出数据和数据下标,一般用在 for 循环当中。

语法
以下是 enumerate() 方法的语法:

enumerate(sequence, [start=0])
参数
sequence -- 一个序列、迭代器或其他支持迭代对象。
start -- 下标起始位置。
返回值
返回 enumerate(枚举) 对象。

lst = ['a','b','c']
print(list(enumerate(lst)))
for i in enumerate(lst):
    print(i)

输出结果:
[(0, 'a'), (1, 'b'), (2, 'c')]
(0, 'a')
(1, 'b')
(2, 'c')

🍁十、all和any内置函数

  • all:用于判断给定的可迭代参数 iterable 中的所有元素是否有bool值为False,如果有则返回 True,否则返回 False。元素除了是 0、空、None、False 外都算 True。
  • any:用于判断给定的可迭代参数 iterable 是否有bool值为 True的元素,如果有一个为 True,没有一个则返回 False。元素除了是 0、空、FALSE 外都算 TRUE。
print(all([1,'','a']))
print(all([1,'a']))
print(all([0,123]))
输出结果:
False
True
False

print(any(['','Ture',123]))
print(any(['',0]))
输出结果:
True
False

🍁十一、zip内置函数

描述
zip() 函数用于将可迭代的对象作为参数,将对象中对应的元素打包成一个个元组,然后返回由这些元组组成的对象,这样做的好处是节约了不少的内存。

我们可以使用 list() 转换来输出列表。

如果各个迭代器的元素个数不一致,则返回列表长度与最短的对象相同,利用 * 号操作符,可以将元组解压为列表。

zip 方法在 Python 2 和 Python 3 中的不同:在 Python 2.x zip() 返回的是一个列表。

语法
zip 语法:

zip([iterable, ...])
参数说明:

iterabl -- 一个或多个迭代器;
返回值
返回一个对象。

l1 = [1,2,3]
l2 = ['a','b','c','d']
l3 = [{1,2},'**']
print(zip(l1,l2))
for i in zip(l1,l2):
    print(i)
print("=======================")
for i in zip(l1,l2,l3):
    print(i)

输出结果:
<zip object at 0x000001967CE0B600>
(1, 'a')
(2, 'b')
(3, 'c')
=======================
(1, 'a', {1, 2})
(2, 'b', '**')

🍁十二、filter和map内置函数

🔥1、filter内置函数

filter() 函数用于过滤序列,过滤掉不符合条件的元素,返回一个迭代器对象,如果要转换为列表,可以使用 list() 来转换。

该接收两个参数,第一个为函数,第二个为序列,序列的每个元素作为参数传递给函数进行判断,然后返回 True 或 False,最后将返回 True 的元素放到新列表中。

def is_odd(x):
    return x % 2 == 1

ret = filter(is_odd,[1,2,4,7,9])
print(ret)
print([i for i in ret])

输出结果:
<filter object at 0x000001FF38B48640>
[1, 7, 9]

🔥2、map内置函数

map() 函数会根据提供的函数对指定序列做映射。

第一个参数 function 以参数序列中的每一个元素调用 function 函数,返回包含每次 function 函数返回值的新列表。

ret = map(abs,[1,-4,6,-9])
print(ret)
print([i for i in ret])

输出结果:
<map object at 0x000001CF1D7C90A0>
[1, 4, 6, 9]

🔥3、总结

   **filter  执行了filter之后的结果集合元素个数 <= 执行之前的个数
            filter只管筛选,执行前后不会改变原来的值
    map     执行前后元素个数保持不变
            map执行前后原来的值可能会发生改变**

🍁十三、sorted内置函数

👉 sorted内置函数使用方法

🍁十四、匿名函数

匿名函数:为了解决那些功能很简单的需求而设计的一句话函数

#将以下函数变为匿名函数
def add1(x,y):
    return x + y

add2 = lambda x,y : x + y

print(add1(1,3))
print(add2(2,4))

输出结果:
4
6

相关文章
|
1月前
|
Python
Python之函数详解
【10月更文挑战第12天】
Python之函数详解
|
1月前
|
存储 数据安全/隐私保护 索引
Python 散列类型三以及函数基础
【10月更文挑战第11天】
Python 散列类型三以及函数基础
|
25天前
|
测试技术 数据安全/隐私保护 Python
探索Python中的装饰器:简化和增强你的函数
【10月更文挑战第24天】在Python编程的海洋中,装饰器是那把可以令你的代码更简洁、更强大的魔法棒。它们不仅能够扩展函数的功能,还能保持代码的整洁性。本文将带你深入了解装饰器的概念、实现方式以及如何通过它们来提升你的代码质量。让我们一起揭开装饰器的神秘面纱,学习如何用它们来打造更加优雅和高效的代码。
|
27天前
|
弹性计算 安全 数据处理
Python高手秘籍:列表推导式与Lambda函数的高效应用
列表推导式和Lambda函数是Python中强大的工具。列表推导式允许在一行代码中生成新列表,而Lambda函数则是用于简单操作的匿名函数。通过示例展示了如何使用这些工具进行数据处理和功能实现,包括生成偶数平方、展平二维列表、按长度排序单词等。这些工具在Python编程中具有高度的灵活性和实用性。
|
29天前
|
Python
python的时间操作time-函数介绍
【10月更文挑战第19天】 python模块time的函数使用介绍和使用。
31 4
|
1月前
|
存储 Python
[oeasy]python038_ range函数_大小写字母的起止范围_start_stop
本文介绍了Python中`range`函数的使用方法及其在生成大小写字母序号范围时的应用。通过示例展示了如何利用`range`和`for`循环输出指定范围内的数字,重点讲解了小写和大写字母对应的ASCII码值范围,并解释了`range`函数的参数(start, stop)以及为何不包括stop值的原因。最后,文章留下了关于为何`range`不包含stop值的问题,留待下一次讨论。
22 1
|
1月前
|
安全 数据处理 数据安全/隐私保护
python中mod函数怎么用
通过这些实例,我们不仅掌握了Python中 `%`运算符的基础用法,还领略了它在解决实际问题中的灵活性和实用性。在诸如云计算服务提供商的技术栈中,类似的数学运算逻辑常被应用于数据处理、安全加密等关键领域,凸显了基础运算符在复杂系统中的不可或缺性。
21 0
Python 函数合集:足足 68 个内置函数,请收好(五)
内置函数就是python给你提供的, 拿来直接用的函数,比如print.,input等。截止到python版本3.6.2 python一共提供了68个内置函数。
Python 函数合集:足足 68 个内置函数,请收好(五)
|
算法 Python
Python 函数合集:足足 68 个内置函数,请收好(四)
内置函数就是python给你提供的, 拿来直接用的函数,比如print.,input等。截止到python版本3.6.2 python一共提供了68个内置函数。
Python 函数合集:足足 68 个内置函数,请收好(四)
Python 函数合集:足足 68 个内置函数,请收好(三)
内置函数就是python给你提供的, 拿来直接用的函数,比如print.,input等。截止到python版本3.6.2 python一共提供了68个内置函数。
Python 函数合集:足足 68 个内置函数,请收好(三)
下一篇
无影云桌面