百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

Python初学者必须掌握的25个内置函数,建议收藏

off999 2024-10-04 19:00 18 浏览 0 评论

收藏前先点个赞哦~


input()

作用:让用户从控制台输入一串字符,按下回车后结束输入,并返回字符串

注意:很多初学者以为它可以返回数字,其实是错的!

>>> line = input("输入一个数字:")
输入一个数字:1
>>> line
'1'  # <-- 看清楚了,这个不是数字,只是字符串


# 如果你直接进行加法……
>>> line + 1   
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
TypeError: can only concatenate str (not "int") to str


# 正确方法,先把 line 转换成数字
>>> int(line) + 1
2

print()

作用:把参数转换成字符串后,输出到控制台

>>> print("hello", "world")
hello world

# 很多人不知道参数之间还可以插入其他字符
>>> print("hello", "world", sep="~")
hello~world

# 甚至可以让每个参数霸占一行
>>> print("hello", "world", sep="\n")
hello
world

set()

作用:构造集合。一个常用的方法是,把列表传入 set(),再转成列表,来实现列表的排重。

>>> set([1, 2, 3, 3])
{1, 2, 3}

# 这样就实现了排重
>>> list(set([1, 2, 3, 3]))
[1, 2, 3]

str()

作用:将对象转换成字符串。常用于字符串和数字的拼接。

例如,这样会报错:

>>> 'My Score is: ' + 100
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
TypeError: can only concatenate str (not "int") to str

所以要用 str 转换一下:

>>> 'My Score is: ' + str(100)
'My Score is: 100'

chr(i)

作用:返回整数 i 所对应的字符,常用于生成字母表。

>>> chr(20013)
'中'
>>> chr(97)
'a'

# 与 ord() 配合,生成字母表
>>> [chr(ord('a') + i) for i in range(26)]
['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z']


ord()

作用:返回字符在编码表中对应的十进制数值

>>> ord('中')
20013
>>> ord('a')
97

# 与 chr() 配合,生成字母表
>>> [chr(ord('a') + i) for i in range(26)]
['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z']


bool()

作用:判断一个对象的布尔值,返回 True 或 False

bool(1) => True
bool(0) => False
bool([]) => False

说明:这个函数在实际项目中很少用,只是作为测试工具,让初学者能了解各对象的布尔状态。

int()

作用:任意进制的字符串转化为整数。

int('2') => 2
int('1010', 2) => 10  # 2进制1010转化为整数10

说明:传入第2个参数,可指定参数1的进制类型。

bin()

作用:把整数转换成2进制的字符串

bin(2) => '0b10'
bin(10) => '0b1010'

说明:为啥字符串前面都有个 0b ?因为这是标准的写法,以 0b 开头表示接下来数字的是2进制。

oct()

作用:将10进制转换为8进制的字符串

oct(7) => '0o7'
oct(8) => '0o10'

hex()

作用:将10进制转换为16进制的字符串

>>> hex(11)
'0xb'

>>> hex(16)
'0x10'

abs()

作用:取绝对值

>>> abs(-1)
1

divmod()

作用:同时返回除法运算中的商和余数,相当于一次运算,同时得到 a//b 和 a% b 的结果。

>>> divmod(1, 2)
(0, 1)

>>> divmod(4, 3)
(1, 1)

round()

作用:对一个浮点数进行四舍五入

>>> round(1.3333)
1

>>> round(1.3333, 2)  # 2 表示保留2位小数
1.33

pow(x, y[, z])

作用:如果只填 x 和 y 参数,则返回 x 的 y 次方。如果填了 z 参数,则再取模,相当于 pow(x, y) % z。

>>> pow(10, 2)
100
# 相当于
>>> 10**2 
100

>>> pow(10, 2, 3)
1
# 相当于
>>> 10**2 % 3 
1

sum(iterable)

作用:对数组 iterable 的所有元素进行求和。

>>> sum([1, 2, 3])
6

min(x, y, z, ...)

作用:返回所有参数中的最小数

>>> min(1, 2, 3)
1

# 传入数组也可以
>>> min([1, 2, 3])
1

max(x, y, z, ...)

作用:类似 min(),返回所有参数中的最大数

list()

作用:传入参数为空时,创建列表;传入参数不为空时,将参数转换成列表

>>> list()
[]

# 不为空时
>>> list('hello world')
['h', 'e', 'l', 'l', 'o', ' ', 'w', 'o', 'r', 'l', 'd']

# 传入字典试试
>>> list({'a': 1, 'b': 2})
['a', 'b']

tuple()

作用:跟 list 几乎一模一样,只不过 list 返回的是数组,tuple 返回的是元组。

dict()

作用:构造字典

# 方法1:
>>> dict(a=1, b=2)
{'a': 1, 'b': 2}

# 方法2:
>>> dict(zip(['a', 'b'], [1, 2]))
{'a': 1, 'b': 2}

# 方法3:
>>> dict([('a', 1), ('b', 2)])
{'a': 1, 'b': 2}

len()

作用:返回对象长度,或元素个数

>>> len([1, 2])
2
>>> len({'a': 1, 'b': 2})
2
>>> len('hello')
5

reversed()

作用:反转列表。

注意:返回的不是列表,是个迭代器。

>>> reversed([1, 2, 3])
<list_reverseiterator object at 0x1016190a0>

# 需要转换成 list
>>> list(reversed([1, 2, 3]))
[3, 2, 1]

# 字符串也一样
>>> reversed('abc')
<reversed object at 0x1015ffd90>
>>> list(reversed('abc'))
['c', 'b', 'a']

enumerate()

作用:用于遍历对象,正常的遍历,比如 for el in array ,只能拿到元素,不能拿到下标,用 enumerate() 就可以。

>>> for i, el in enumerate('abc'):
...     print(i, el)
...
0 a
1 b
2 c

这个下标怎么用呢?比如可以用来反过来修改数组内的元素:

>>> alphabet = ['a', 'b', 'c']
>>> for i, el in enumerate(alphabet):
...     alphabet[i] = el.upper()
...
>>> alphabet
['A', 'B', 'C']

filter(func, iterable)

作用:过滤并返回符合条件的元素

注意:返回的是一个迭代器。

>>> alphabet = ['a', 'b', 'c', 'E', 'F', 'G']

>>> filter(lambda e: e.isupper(), alphabet)
<filter object at 0x1016190a0>

>>> list(filter(lambda e: e.isupper(), alphabet))
['E', 'F', 'G']

相关推荐

python爬取电子课本,送给居家上课的孩子们

在这个全民抗疫的日子,中小学生们也开启了居家上网课的生活。很多没借到书的孩子,不得不在网上看电子课本,有的电子课本是老师发的网络链接,每次打开网页去看,既费流量,也不方便。今天我们就利用python的...

高效办公!Python 批量生成PDF文档是如何做到的?

前言:日常办公中,经常会使用PDF文档,难免需要对PDF文档进行编辑,有时候PDF文档中的大部分内容都是一样的,只是发送对象不同。这种模板套用的场景下,使用Python进行自动化就尤为方便,用最短的时...

如何用Python将PDF完整的转成Word?

PDF文件完整的转为Word,转换后格式排版不会乱,图片等信息完整显示不丢失。这个很简单,有很多方法都可以实现。方法一:Python利用Python将PDF文件转换为Word,有许多库可以帮你实现这一...

使用Python拆分、合并PDF(python合并多个pdf)

知识点使用Python操作PDF!主要内容有:1、PDF拆分;2、PDF合并。在工作中,难免会和PDF打交道,所以掌握一点处理PDF的技能非常有必要,本文将介绍几个常用的功能。PDF拆分很多时候,获取...

10分钟实现PDF转Word神器!看DeepSeek如何用Python解放打工人

开篇痛点每个被PDF折磨过的职场人都懂——领导发来的扫描件要修改,手动抄到Word需要2小时;网上下载的报告想复制数据,却变成乱码…今天我们用Python+DeepSeek,10分钟打造一个智能转换工...

《Python知识手册》,高清全彩pdf版开放下载

Python编程还不懂?今天我要把我参与编写的这套《Python知识手册》免费分享出来,看完文末有惊喜哦。...

利用python进行数据分析,PDF文档给你答案

本书详细介绍利用Python进行操作、处理、清洗和规整数据等方面的具体细节和基本要点。虽然本书的标题是“数据分析”,重点却是Python编程、库,以及用于数据分析的工具。兄弟,毫无套路!PDF版无偿获...

OCRmypdf:一款可以让扫描PDF文件变得可搜索、可复制!

简介在日常工作中,我们经常会接触到各种PDF文件,其中不少是扫描版文档。处理这些扫描PDF时,尽管内容看似完整,但往往无法直接复制或搜索其中的文本。尤其是在需要对大量文档进行文本分析、存档或后期编辑时...

高效的OCR处理工具!让扫描PDF文件变得可搜索、可复制!

在工作中,我们常常遇到各种各样的PDF文件,其中不乏一些扫描版的文档。而在处理扫描的PDF文件时,虽然文件内容看似完整,但你却无法复制、搜索其中的文本。特别是对大量文档需要进行文本分析、存档、或者...

三步教你用Elasticsearch+PyMuPDF实现PDF大文件秒搜!

面对100页以上的大型PDF文件时,阅读和搜索往往效率低下。传统关系型数据库在处理此类数据时容易遇到性能瓶颈,而Elasticsearch凭借其强大的全文检索和分布式架构,成为理想解决方案。通过...

用 Python 去除 PDF 水印,你学会吗?

今天介绍下用Python去除PDF(图片)的水印。思路很简单,代码也很简洁。首先来考虑Python如何去除图片的水印,然后再将思路复用到PDF上面。这张图片是前几天整理《数据结构和算法...

扫描PDF档案效率提升300%!OCRmyPDF:告别无法搜索的PDF噩梦,这款26K Star的开源神器让文本识别轻松上手!

要在PDF中搜索某个关键词,结果发现啥也找不到?这种情况大多数人都遇到过吧,特别是处理扫描文档或图片PDF时。就在前几天,我还在为这事抓狂呢!后来无意中发现了OCRmyPDF这个宝藏项目...简直就...

Python自动化办公之PDF版本发票识别并提取关键信息教程(上篇)

大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Python自动化办公发票数据处理的问题,一起来看看吧。二、实现过程这个问题在实际工作中还是非常常见的,实用性和通用性都比...

PDF解锁神器:用PyMuPDF与pdfplumber告别手动提取

前言大家好,今天咱们来聊聊如何用Python中的PyMuPDF和pdfplumber库,轻松提取PDF文件里的文本和元数据。你是否曾经在处理一个复杂的PDF文件时,感到信息难以触及,提取过程让人抓狂?...

《Python知识手册》,高清pdf免费获取

今天我要把我参与编写的这套《Python知识手册》免费分享出来,真正弘扬Python开源精神!手册的部分页面如下:获取方式:...

取消回复欢迎 发表评论: