Python3,不知道Python内置库函数,不要错过这篇,必须收藏!!!

简介: Python3,不知道Python内置库函数,不要错过这篇,必须收藏!!!

1、引言

最近在整理我的小作业本,顺便翻到了Python内置库,

感觉自己在小本本上写的也挺凌乱的,索性一不做二不休,

重新整理!

小屌丝:鱼哥,你终于作对了一件有意义的事情。

小鱼:What

小屌丝:你脱什么你脱,赶紧分享干货!!

此时小鱼的表情,就是这样的!!

而小屌丝的表情,是这样的!!

2、内置库详解

Python一共提供了68个内置函数,我们先看一下,都

有哪些

abs()           dict()        help()         min()         setattr()
all()           dir()         hex()          next()        slice() 
any()           divmod()      id()           object()      sorted() 
ascii()         enumerate()   input()        oct()         staticmethod() 
compile()       globals()     map()          reversed()    __import__() 
complex()       hasattr()     max()          round() 
delattr()       hash()        memoryview()   set()
bin()           eval()        int()          open()        str() 
bool()          exec()        isinstance()   ord()         sum() 
bytearray()     filter()       issubclass()   pow()         super() 
bytes()         float()        iter()         print()       tuple() 
callable()      format()      len()          property()    type() 
chr()           frozenset()   list()         range()       vars() 
classmethod()   getattr()     locals()       repr()        zip() 

小屌丝:唉我去~~ 这么多,我怎么记得住?

小鱼:如果这68个内置库想象成妹子的兴趣爱好,然后对应12个妹子,你能能记住吗???

小屌丝:那…这… 必须能啊。

小鱼:… 你真的是…

小屌丝:有妹子,好办事! !

我们把这68个内置函数,分成12个大类,如下:

  • 数据相关
  • 数据结构相关
  • 作用域相关
  • 迭代器生成器相关
  • 字符串类型代码的执行
  • 输入输出
  • 内存相关
  • 文件操作相关
  • 模块相关
  • 帮助
  • 查看内置属性
  • 调用相关

2.1 数据

2.1.1 数学运算

  • abs() 返回绝对值
  • divmode() 返回商和余数
  • round() 四舍五入
  • pow(a, b) 求a的b次幂, 如果有三个参数. 则求完次幂后对第三个数取余
  • sum() 求和
  • min() 求最小值
  • max() 求最大值

代码展示:

# 绝对值
print(abs(-4)) 
# 求商和余数
print(divmod(20,3)) 
# 四舍五入
print(round(12.34))
# 取余:1
print(pow(11,3,2))  
# 求和:55
print(sum([11,22,33,44,55,66,77,88])) 
 #最小值:6 
print(min(25,13,99,42,6,10)) 
#最大值:99
print(max(25,13,99,42,6,10))  

结果截图:

2.1.2 数据类型

  • bool : 布尔型(True,False)
  • int : 整型(整数)
  • float : 浮点型(小数)
  • complex : 复数

2.1.3 进制制转换

  • bin() :将转换成二进制
  • otc() :将转换成八进制
  • hex() :将转换成十六进制

代码展示:

#八进制
print(oct(8))  
#二进制
print(bin(8)) 
#十六进制
print(hex(8))  

结果截图:

2.2 数据结构相关

2.2.1 序列

1、列表和元组

  • list() 将一个可迭代对象转换成列表
  • tuple() 将一个可迭代对象转换成元组

代码展示:

 #列表输出
print(list((11,12,13,14,15,16))) 
#元组输出
print(tuple([11,12,13,14,15,16]))  

结果截图:

2、切片和翻转

  • reversed() 将一个序列翻转, 返回翻转序列的迭代器
  • slice() 列表切片

代码展示:

#定义list
lst = "carl_奕然"
# 返回一个迭代器
res = reversed(lst) 
#输出结果:['然', '奕', '_', 'l', 'r', 'a', 'c']
print(list(res))  

结果截图:

#定义list
lst = [10, 11, 12, 13, 14, 15, 16]
#输出结果:[12, 13, 14, 15]
print(lst[2:6:1])  
#切片
spl = slice(2, 6, 1) 
#输出结果[12, 13, 14, 15]
print(lst[spl]) 

结果截图:

3、字符串

  • str() 将数据转化成字符串

代码展示:

res = "hello Carl_奕然!"
#居中,
print(format(res, "^30")) 
#左对齐 
print(format(s, "<30"))
#右对齐
print(format(s, ">30")) 

结果截图:

# 二进制:6
print(format(6, 'd' ))
# 转换成unicode字符:o    
print(format(111, 'c' )) 
# ⼗进制:11 
print(format(11, 'd' )) 
# 八进制:13  
print(format(11, 'o' )) 
# 十六进制(⼩写字母):b  
print(format(11, 'x' ))
# 十六进制(大写字母):B   
print(format(11, 'X' )) 
 # 小数点计数法. 保留4位小数:2.3456   
print(format(2.341567289, '0.4f' )) 
# 小数点计数法. 保留6位小数:2.341567  
print(format(2.341567289, 'f' ))
# 科学计数法: 默认保留6位小数:2.341567e+09
print(format(2341567289, 'e' )) 
 # 科学计数法: 保留4位小数:1.23e+08    
print(format(2341567289, '0.4e' ))

输出结果:

  • bytes() :把字符串转化成bytes类型
as
ast = bytes("今天下雨呢!!", encoding="utf-8")
#输出结果:b'\xe4\xbb\x8a\xe5\xa4\xa9\xe4\xb8\x8b\xe9\x9b\xa8\xe5\x91\xa2\xef\xbc\x81\xef\xbc\x81'
print(ast)  
   bytearray()    #返回一个新字节数组,并且每个元素的值得范围都是[0,256)
rst = bytearray("alex" ,encoding ='utf-8')
#输出结果:108
print(rst[1])  
#输出结果:bytearray(b'alex')
print(rst)  
#把108的位置A赋值给ret[1]
rst[1] = 108 
#输出结果;#bytearray(b'alex')
print(str(rst))  
  • ord(): 输入字符找带字符编码的位置
  • chr() :输入位置数字找出对应的字符
  • ascii() :是ascii码中的返回该值 不是就返回u
# 获取字母s在编码表中的码位:115
print(ord('s'))  
# '国'字在编码表中的位置:22269
print(ord('国'))  
# 已知码位,求字符:c
print(chr(99))   
for i in range(65536):  
  #把65535的字符都打印出來,可以参照截图
    print(chr(i), end=" ")

输出结果截图:

把65535的字符都打印出來

  • repr() 返回一个对象的string形式
res = "小鱼\n今天撩了%d个 妹子" % 1 
print(res) 
#输出结果:小鱼
         #今天撩了1个 妹子
#原样输出
print(repr(res))   
#输出结果:'小鱼\n今天撩了1个 妹子'

2.2.2 数据集合

字典:dict 创建字典

集合:set 创建集合

frozenset() 创建一个冻结的集合,

注:

冻结的集合不能进行添加和删除操作。

2.2.3 内置函数

len() 返回对象中的元素的个数


sorted() 对可迭代对象进行排序操作 (lamda)

语法:sorted(Iterable, key=函数(排序规则), reverse=False)


Iterable: 可迭代对象


key: 排序规则(排序函数), 在sorted内部会将可迭代对象中的每一个元素传递给这个函数的参数。根据函数运算的结果进行排序


reverse: 是否是倒叙. True: 倒叙, False: 正序

代码展示:

#定义list
lst = [25,7,16,92,11,63,889,100,1]
# sort是list里面的一个方法
lst.sort()  
#输出结果:[1, 7, 11, 16, 25, 63, 92, 100, 889]
print(lst)  
# 内置函数. 返回一个新的且被排序的列表 
lat = sorted(lst) 
#输出结果:[1, 7, 11, 16, 25, 63, 92, 100, 889]
print(lat)  
#倒序
ldt = sorted(lst,reverse=True)  
#输出结果:[889, 100, 92, 63, 25, 16, 11, 7, 1]
print(l2)  

结果截图:

  • enumerate() :获取集合的枚举对象
lst = ['one','two','three','four','five']
# 同时获取索引和元素,索引默认从0开始,但是可更改
for index, el in enumerate(lst,1):    
    print(index)
    print(el)

结果截图:

  • all(): 迭代对象全部为True,才返回True
  • any() :迭代对象一个为True,就返回True
#输出结果:True
print(all([11,'carl_奕然',True]))  
#输出结果:True
print(any([99,False,'Nice',97,True])) 

结果截图:

  • zip() :将可迭代的对象作为参数, 把对象中对应的元素打包成一个元组, 返回列表。

    如果各个迭代器的元素个数不一致, 则返回列表长度与最短的对象相同。
lst1 = [1, 2, 3, 4, 5, 6]
lst2 = ['异型', '小兵张嘎', '急速快递', '人生不可重来', '这是一道伪命题', '白马王子的一生']
lst3 = ['MA', 'CN', 'FR', 'ITA', 'KR', 'SE']
print(zip(lst1, lst1, lst3))  
for sa in zip(lst1, lst2, lst3):
    print(sa)

结果截图:

  • fiter() :过滤 (lamda)
    语法:fiter(function. Iterable)

function: 用来筛选的函数。

①在filter中会自动的把iterable中的元素传递给function;

②然后根据function返回的True或者False来判断是否保留留此项数据 ,

Iterable: 可迭代对象。

# 判断奇数
def func(i):    
    return i % 2 == 1
    lst = [11,22,33,44,55,66,77]
#ls是迭代器
la = filter(func, lst)  
#<filter object at 0x000001CE3CA98AC8>
print(la)  

结果截图:

  • map() :根据提供的函数对指定序列做映射(lamda)
    语法 : map(function, iterable)
    注:
    可以对可迭代对象中的每一个元素进行映射。
    分别去执行 function
def f(i):   
  return i
lst = [11,12,13,14,15,16,17]
 # 把可迭代对象中的每一个元素传递给前面的函数进行处理并返回迭代器
st = map(f, lst)
print(list(it)) 

截图截图:

2.3 作用域相关

  • locals() :返回当前作用域中的名字
  • globals() :返回全局作用域中的名字
def func():
    a = 10
    # 打印当前作用域中的内容
    print(locals())
    # 打印全局作用域中的内容  
    print(globals())  
    print("打印全部内容")
func()

结果截图:

2.4 迭代器生成器相关

  • range() :生成数据
  • next() :迭代器向下执行一次, 内部实际使⽤用了__ next__()方法返回迭代器的下一个项目
  • iter() :获取迭代器, 内部实际使用的是__ iter__()方法来获取迭代器
for i in range(25,-1,-3):
    print(i)

结果截图:

lst = [11,12,13,14,15]
st = iter(lst)  #  __iter__()获得迭代器
print(st.__next__())
#第一次
print(next(st))  
#第二次
print(next(st))  

结果截图:

2.5 字符串类型代码的执行

  • eval() :执行字符串类型的代码. 并返回最终结果
  • exec() :执行字符串类型的代码
  • compile(): 将字符串类型的代码编码。代码对象能够通过exec语句来执行或者eval()进行求值
#输入:8+9
st1 = input("请输入a+b:")  
# 17 可以动态的执行代码. 代码必须有返回值
print(eval(st1))  
st2 = "for i in range(9): print(i)"
# exec 执行代码不返回任何内容
ast = exec(st2) 
print(ast)  #None

结果截图:

# 动态执行代码
exec("""
def func():
    print(" 我是Carl_奕然")
""" )
func()  #我是Carl_奕然

结果截图:

code1 = "for i in range(9): print(i)"
# compile并不会执行你的代码.只是编译
cst = compile(code1, "", mode="exec")   
# 执行编译的结果
exec(com)   

结果截图:

code2 = "1+2+3+4"
cst2 = compile(code2, "", mode="eval")
print(eval(cst2))

结果截图:

code3 = "sexuality = input('请输入你的性别:')"  
cst3 = compile(code3, "", mode="single")
exec(cst3)
print(sexuality)

结果截图:

2.6 输入输出

  • print() : 打印输出
  • input() : 获取用户输出的内容
#sep:打印出的内容用什么连接,end:以什么为结尾
print("Hello", "Carl_奕然", sep=",", end="★") 

结果截图:

2.7 内存相关

hash() : 获取到对象的哈希值(int, str, bool, tuple)。

hash算法:

  • 目的是唯一性
  • dict 查找效率非常高,

hash表:用空间换的时间 比较耗费内存。

2.8 文件操作相关

open() : 用于打开一个文件, 创建一个文件句柄

f = open('filepath',mode='w',encoding='utf-8')
f.read()
f.close()

2.9 模块相关

__ import__() : 用于动态加载类和函数

# 让用户输入一个要导入的模块
import os
path = input("你要导入的模块:")
__import__(path)    # 可以动态导入模块

2.10 调用相关

  • callable() : 用于检查一个对象是否是可调用的。

如果返回True, object有可能调用失败;

但如果返回False. 那调用绝对不会成功。

sat = 11
print(callable(sat))  #False  

2.11 帮助

  • help() : 函数用于查看函数或模块用途的详细说明
#help调用
print(help())
#查看字符串的用途
print(help(str))  

2.11 帮助

  • help() : 函数用于查看函数或模块用途的详细说明
#help调用
print(help())
#查看字符串的用途
print(help(str))  

结果截图:

2.12 查看内置属性

  • dir() : 查看对象的内置属性, 访问的是对象中的__dir__()方法
print(dir())
#查看列表
print(dir(list))
#查看元组
print(dir(tuple))

结果截图:

3、总结

小屌丝:呦呵~ 这整理的,挺立正啊!

小鱼:这还行吧,毕竟我很谦虚的。

写到这里,Python的内置库函数,也算是整理的明明白白的了。

当然,我们也可以参照官方文档来学习,

但是,官方文档,没有小鱼写的这么生动活泼。

所以,小鱼建议,先收藏,在学习,毕竟,一次性记住这么多内置函数,有点难。

如果智商跟小鱼一样高,可以一试。

毕竟,超过50的,都是普通人

最后,瞅瞅时间,泡杯咖啡,小鱼也该写作业去了~ ~

目录
相关文章
|
9天前
|
机器学习/深度学习 存储 数据挖掘
Python图像处理实用指南:PIL库的多样化应用
本文介绍Python中PIL库在图像处理中的多样化应用,涵盖裁剪、调整大小、旋转、模糊、锐化、亮度和对比度调整、翻转、压缩及添加滤镜等操作。通过具体代码示例,展示如何轻松实现这些功能,帮助读者掌握高效图像处理技术,适用于图片美化、数据分析及机器学习等领域。
49 20
|
1月前
|
XML JSON 数据库
Python的标准库
Python的标准库
173 77
|
2月前
|
搜索推荐 Python
利用Python内置函数实现的冒泡排序算法
在上述代码中,`bubble_sort` 函数接受一个列表 `arr` 作为输入。通过两层循环,外层循环控制排序的轮数,内层循环用于比较相邻的元素并进行交换。如果前一个元素大于后一个元素,就将它们交换位置。
148 67
|
14天前
|
Python
[oeasy]python057_如何删除print函数_dunder_builtins_系统内建模块
本文介绍了如何删除Python中的`print`函数,并探讨了系统内建模块`__builtins__`的作用。主要内容包括: 1. **回忆上次内容**:上次提到使用下划线避免命名冲突。 2. **双下划线变量**:解释了双下划线(如`__name__`、`__doc__`、`__builtins__`)是系统定义的标识符,具有特殊含义。
26 3
|
18天前
|
JSON 监控 安全
深入理解 Python 的 eval() 函数与空全局字典 {}
`eval()` 函数在 Python 中能将字符串解析为代码并执行,但伴随安全风险,尤其在处理不受信任的输入时。传递空全局字典 {} 可限制其访问内置对象,但仍存隐患。建议通过限制函数和变量、使用沙箱环境、避免复杂表达式、验证输入等提高安全性。更推荐使用 `ast.literal_eval()`、自定义解析器或 JSON 解析等替代方案,以确保代码安全性和可靠性。
28 2
|
3天前
|
存储 人工智能 Python
[oeasy]python061_如何接收输入_input函数_字符串_str_容器_ 输入输出
本文介绍了Python中如何使用`input()`函数接收用户输入。`input()`函数可以从标准输入流获取字符串,并将其赋值给变量。通过键盘输入的值可以实时赋予变量,实现动态输入。为了更好地理解其用法,文中通过实例演示了如何接收用户输入并存储在变量中,还介绍了`input()`函数的参数`prompt`,用于提供输入提示信息。最后总结了`input()`函数的核心功能及其应用场景。更多内容可参考蓝桥、GitHub和Gitee上的相关教程。
7 0
|
1月前
|
Python
Python中的函数是**一种命名的代码块,用于执行特定任务或计算
Python中的函数是**一种命名的代码块,用于执行特定任务或计算
57 18
|
1月前
|
数据可视化 DataX Python
Seaborn 教程-绘图函数
Seaborn 教程-绘图函数
73 8
|
1月前
|
XML JSON 数据库
Python的标准库
Python的标准库
56 11
|
2月前
|
人工智能 API 开发工具
aisuite:吴恩达发布开源Python库,一个接口调用多个大模型
吴恩达发布的开源Python库aisuite,提供了一个统一的接口来调用多个大型语言模型(LLM)服务。支持包括OpenAI、Anthropic、Azure等在内的11个模型平台,简化了多模型管理和测试的工作,促进了人工智能技术的应用和发展。
160 1
aisuite:吴恩达发布开源Python库,一个接口调用多个大模型