资讯专栏INFORMATION COLUMN

Python3,68个内置库函数详解,进阶必备,必须收藏!!!

lindroid / 2822人阅读

摘要:判断奇数是迭代器会根据提供的函数对指定序列做映射语法可以对可迭代对象中的每一个元素进行映射。

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() 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() compile()       globals()     map()          reversed()    __import__() complex()       hasattr()     max()          round() delattr()       hash()        memoryview()   set()

小屌丝:唉我去~~ 这么多,我怎么记得住?
小鱼:如果这68个内置库想象成妹子的兴趣爱好,然后对应12个妹子,你能能记住吗???
小屌丝:那…这… 必须能啊。
小鱼:… 你真的是…
小屌丝:有妹子,好办事! !

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

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

2.1 数据相关

2.1.1 数据类型

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

2.1.2 进制转换

  • bin() 将给的参数转换成二进制
  • otc() 将给的参数转换成八进制
  • hex() 将给的参数转换成十六进制

代码展示:

#输出结果:二进制:0b1010print(bin(10)) #输出结果: 十六进制:0xa print(hex(10))  #输出结果:八进制:0o12print(oct(10))  

2.1.3 数学运算

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

代码展示:

# 绝对值:2print(abs(-2)) # 求商和余数:(6,2) print(divmod(20,3)) # 五舍六入:4print(round(4.50))#5   print(round(4.51))   # 如果给了第三个参数. 表示最后取余:1print(pow(10,2,3))  # 求和:55print(sum([1,2,3,4,5,6,7,8,9,10]))  #求最小值:2 print(min(5,3,9,12,7,2)) #求最大值:15print(max(7,3,15,9,4,13))  

2.2 数据结构相关

2.2.1 序列

1、列表和元组

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

代码展示:

 #输出结果:[1, 2, 3, 4, 5, 6]print(list((1,2,3,4,5,6))) #输出结果:(1, 2, 3, 4, 5, 6)print(tuple([1,2,3,4,5,6]))  

2、相关内置函数

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

代码展示:

#定义listlst = "你好啊"# 不会改变原列表. 返回一个迭代器, 设计上的一个规则it = reversed(lst) #输出结果:["啊", "好", "你"]print(list(it))  #定义listlst = [1, 2, 3, 4, 5, 6, 7]#输出结果:[2,3]print(lst[1:3:1])  #切片s = slice(1, 3, 1) #输出结果[2,3]print(lst[s]) 

3、字符串

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

代码展示:

#输出结果:123456print(str(123)+"456")    format()     #与具体数据相关, 用于计算各种小数, 精算等  
s = "hello world!"#剧中print(format(s, "^20")) #左对齐 print(format(s, "<20"))  #右对齐print(format(s, ">20")) # 二进制:11print(format(3, "b" ))# 转换成unicode字符:a    print(format(97, "c" ))  # ⼗进制:11 print(format(11, "d" ))  # 八进制:13  print(format(11, "o" )) # 十六进制(⼩写字母):b  print(format(11, "x" ))# 十六进制(大写字母):B   print(format(11, "X" )) # 和d⼀样:11  print(format(11, "n" ))  # 和d⼀样:11 print(format(11))         # 科学计数法. 默认保留6位小数:1.234568e+08print(format(123456789, "e" ))   # 科学计数法. 保留2位小数(小写):1.23e+08    print(format(123456789, "0.2e" ))# 科学计数法. 保留2位小数(大写):1.23E+08  print(format(123456789, "0.2E" )) # 小数点计数法. 保留6位小数:1.234568  print(format(1.23456789, "f" ))   # 小数点计数法. 保留2位小数:1.23   print(format(1.23456789, "0.2f" )) # 小数点计数法. 保留10位小数:1.2345678900print(format(1.23456789, "0.10f"))# 小数点计数法. 很大的时候输出INF:1234.567890  print(format(1.23456789e+3, "F"))   
  • bytes() 把字符串转化成bytes类型
bs = bytes("今天吃饭了吗", encoding="utf-8")#输出结果:b"/xe4/xbb/x8a/xe5/xa4/xa9/xe5/x90/x83/xe9/xa5/xad/xe4/xba/x86/xe5/x90/x97"print(bs)     bytearray()    #返回一个新字节数组. 这个数字的元素是可变的, 并且每个元素的值得范围是[0,256)ret = bytearray("alex" ,encoding ="utf-8")#输出结果:97print(ret[0])  #输出结果:bytearray(b"alex")print(ret)  #输出结果:#把65的位置A赋值给ret[0]ret[0] = 65  #输出结果;#bytearray(b"Alex")print(str(ret))  
  • ord() 输入字符找带字符编码的位置
  • chr() 输入位置数字找出对应的字符
  • ascii() 是ascii码中的返回该值 不是就返回u
# 字母a在编码表中的码位:97print(ord("a"))  # "中"字在编码表中的位置:20013print(ord("中"))  # 已知码位,求字符是什么:Aprint(chr(65))  print(chr(19999))  for i in range(65536):  	#打印出0到65535的字符    print(chr(i), end=" ")#输出结果:"@"print(ascii("@"))  
  • repr() 返回一个对象的string形式
s = "今天/n吃了%s顿/t饭" % 3print(s) #输出结果:今天# 吃了3顿    饭print(repr(s))   # 原样输出,过滤掉转义字符 /n /t /r 不管百分号%#输出结果:"今天/n吃了3顿/t饭"

2.2.2 数据集合

  • 字典:dict 创建一个字典
  • 集合:set 创建一个集合

frozenset() 创建一个冻结的集合,冻结的集合不能进行添加和删除操作。

2.2.3 相关内置函数

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

  • sorted() 对可迭代对象进行排序操作 (lamda)
    语法:sorted(Iterable, key=函数(排序规则), reverse=False)

  • Iterable: 可迭代对象

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

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

代码展示:

lst = [5,7,6,12,1,13,9,18,5]# sort是list里面的一个方法lst.sort()  #输出结果:[1, 5, 5, 6, 7, 9, 12, 13, 18]print(lst)  # 内置函数. 返回给你一个新列表  新列表是被排序的ll = sorted(lst) #输出结果:[1, 5, 5, 6, 7, 9, 12, 13, 18]print(ll)  #倒序l2 = sorted(lst,reverse=True)  #输出结果:[18, 13, 12, 9, 7, 6, 5, 5, 1]print(l2)  
#根据字符串长度给列表排序lst = ["one", "two", "three", "four", "five", "six"]def f(s):    return len(s)l1 = sorted(lst, key=f, )#输出结果:["one", "two", "six", "four", "five", "three"]print(l1)  
  • enumerate() 获取集合的枚举对象
lst = ["one","two","three","four","five"]# 把索引和元素一起获取,索引默认从0开始. 可以更改for index, el in enumerate(lst,1):        print(index)    print(el)# 1# one# 2# two# 3# three# 4# four# 5# five
  • all() 可迭代对象中全部是True, 结果才是True
  • any() 可迭代对象中有一个是True, 结果就是True
#输出结果:Trueprint(all([1,"hello",True,9]))  #输出结果:Trueprint(any([0,0,0,False,1,"good"]))  
  • zip() 函数用于将可迭代的对象作为参数, 将对象中对应的元素打包成一个元组, 然后返回由这些元组组成的列表. 如果各个迭代器的元素个数不一致, 则返回列表长度与最短的对象相同
lst1 = [1, 2, 3, 4, 5, 6]lst2 = ["醉乡民谣", "驴得水", "放牛班的春天", "美丽人生", "辩护人", "被嫌弃的松子的一生"]lst3 = ["美国", "中国", "法国", "意大利", "韩国", "日本"]print(zip(lst1, lst1, lst3))  #for el in zip(lst1, lst2, lst3):    print(el)# (1, "醉乡民谣", "美国")# (2, "驴得水", "中国")# (3, "放牛班的春天", "法国")# (4, "美丽人生", "意大利")# (5, "辩护人", "韩国")# (6, "被嫌弃的松子的一生", "日本")
  • fiter() 过滤 (lamda)
    语法:fiter(function. Iterable)

function: 用来筛选的函数。
①在filter中会自动的把iterable中的元素传递给function;
②然后根据function返回的True或者False来判断是否保留留此项数据 ,
Iterable: 可迭代对象。

def func(i):    # 判断奇数    return i % 2 == 1    lst = [1,2,3,4,5,6,7,8,9]#l1是迭代器l1 = filter(func, lst)  #print(l1)  #[1, 3, 5, 7, 9]print(list(l1))  
  • map() 会根据提供的函数对指定序列列做映射(lamda)
    语法 : map(function, iterable)

可以对可迭代对象中的每一个元素进行映射。
分别去执行 function

def f(i):    return ilst = [1,2,3,4,5,6,7,] # 把可迭代对象中的每一个元素传递给前面的函数进行处理. 处理的结果会返回成迭代器it = map(f, lst)#输出结果:[1, 2, 3, 4, 5, 6, 7]print(list(it))  

2.3 作用域相关

  • locals() 返回当前作用域中的名字
  • globals() 返回全局作用域中的名字
def func():    a = 10    # 当前作用域中的内容    print(locals())    # 全局作用域中的内容      print(globals())      print("今天内容很多")func()# {"a": 10}# {"__name__": "__main__", "__doc__": None, "__package__": None, "__loader__": # <_frozen_importlib_external.SourceFileLoader object at 0x0000026F8D566080>, # "__spec__": None, "__annotations__": {}, "__builtins__": # (built-in)>, "__file__": "D:/pycharm/练习/week03/new14.py", "__cached__": None,#  "func": }# 今天内容很多

2.4 迭代器生成器相关

  • range() 生成数据
  • next() 迭代器向下执行一次, 内部实际使⽤用了__ next__()方法返回迭代器的下一个项目
  • iter() 获取迭代器, 内部实际使用的是__ iter__()方法来获取迭代器
for i in range(15,-1,-5):    print(i)# 15# 10# 5# 0lst = [1,2,3,4,5]it = iter(lst)  #  __iter__()获得迭代器print(it.__next__())  #1print(next(it)) #2  __next__()  print(next(it))  #3print(next(it))  #4

2.5 字符串类型代码的执行

  • eval() 执行字符串类型的代码. 并返回最终结果
  • exec() 执行字符串类型的代码
  • compile() 将字符串类型的代码编码。代码对象能够通过exec语句来执行或者eval()进行求值
#输入:8+9s1 = input("请输入a+b:")  # 17 可以动态的执行代码. 代码必须有返回值print(eval(s1))  s2 = "for i in range(5): print(i)"# exec 执行代码不返回任何内容a = exec(s2) # 0# 1# 2# 3# 4print(a)  #None# 动态执行代码exec("""def func():    print(" 我是Carl_奕然")""" )func()  #我是Carl_奕然
code1 = "for i in range(3): print(i)"# compile并不会执行你的代码.只是编译com = compile(code1, "", mode="exec")   # 执行编译的结果exec(com)   # 0# 1# 2code2 = "5+6+7"com2 = compile(code2, "", mode="eval")print(eval(com2))  # 18code3 = "name = input("请输入你的名字:")"  #输入:hellocom3 = compile(code3, "", mode="single")exec(com3)print(name)  #hello

2.6 输入输出

  • print() : 打印输出
  • input() : 获取用户输出的内容
#sep:打印出的内容用什么连接,end:以什么为结尾print("hello", "world", sep="*", end="@") #输出结果:hello*world@

2.7 内存相关

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

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

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

2.8 文件操作相关

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

f = open("file",mode="r",encoding="utf-8")f.read()f.close()

2.9 模块相关

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

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

2.10 调用相关

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

如果返回True, object有可能调用失败;
但如果返回False. 那调用绝对不会成功。

a = 
                 
               
              

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/121146.html

相关文章

  • 首次公开,整理12年积累的博客收藏夹,零距离展示《收藏夹吃灰》系列博客

    摘要:时间永远都过得那么快,一晃从年注册,到现在已经过去了年那些被我藏在收藏夹吃灰的文章,已经太多了,是时候把他们整理一下了。那是因为收藏夹太乱,橡皮擦给设置私密了,不收拾不好看呀。 ...

    Harriet666 评论0 收藏0
  • FED之必备技能 - 收藏集 - 掘金

    摘要:收藏优秀组件库合集前端掘金开源的优秀组件库合集教你如何在应用程序中使用本地文件上传图片前端掘金使用在中添加到的,现在可以让内容要求用户选择本地文件,然后读取这些文件的内容。 『收藏』VUE 优秀 UI 组件库合集 - 前端 - 掘金github 开源的 Vue 优秀 UI 组件库合集✔... 教你如何在 web 应用程序中使用本地文件•上传图片file✔ - 前端 - 掘金使用在HTM...

    lyning 评论0 收藏0
  • 那些年,我的前端/Java后端书单

    摘要:全文为这些年,我曾阅读深入理解过或正在阅读学习即将阅读的一些优秀经典前端后端书籍。当然,如果您喜欢这篇文章,可以动手点点赞或者收藏。 全文为这些年,我曾阅读、深入理解过(或正在阅读学习、即将阅读)的一些优秀经典前端/Java后端书籍。全文为纯原创,且将持续更新,未经许可,不得进行转载。当然,如果您喜欢这篇文章,可以动手点点赞或者收藏。 基础 基础书籍 进阶 进阶阶段,深入学习的书...

    fxp 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<