python常用内置函数和关键字

常用内置方法

在Python中有许许多多的内置方法,就是一些Python内置的函数,它们是我们日常中经常可以使用的到的一些基础的工具,可以方便我们的工作。

方法一
built_list = dir(__builtins__)

方法二
import builtins
built_list = dir(builtins)

其中,以 Error或者 Warning等是Python中的异常类(关于异常可以参考后面的异常学习),以 __开头和结尾的是内置的一些魔术方法(关于魔术方法可以参考面向对象的学习)、剩余的就是一些常用的内置类和方法。

打印(输出)指定的内容,可以打印多内容(多个参数)

语法: print(*args)

参数 说明 *args 输出的内容,数量任意,任何内容都可以; sep 指定输出内容之间的间隔符,必须是字符串,默认为一个空格; end 最后追加的内容,使用print之后最后追加的内容,必须是字符串,默认是一个换行符 \n; file 将输出的内容写入指定的文件对象中。

常规用法
print(1)  # 1
print(1, 2, 3)  # 1 2 3

sep参数
print(1, 2, 3)  # 1 2 3
print(1, 2, 3, sep=' MSR ')  # 1 MSR 2 MSR 3

end参数
print(1, 2)
print(3, 4)
'''
1 2
3 4
'''
print(1, 2, end='')
print(3, 4)
'''
1 23 4
'''

file参数
fp = open('test.txt', 'w', encoding='UTF-8')
print('Hello Word.', file=fp)

返回输入的结果, 返回的结果为字符串类型;输入时,接收到enter(回车)时将输入内容返回;

input_content = input()  # 输入 -- Hello MSR.

print(input_content)  # Hello MSR.

可以在input中输入内容,作为交互信息(就是一个标准输出)
input('请输入你的银行卡密码:')

返回数字的绝对值,唯一参数必须说是数字类型,即:int float bool complex

res = abs(-100)
print(res)  # 100

res = abs(True)
print(res)  # 1

返回一个十进制数字四舍五入后的结果

参数 说明 number 四舍五入的数字 ndigits 保留的小数位数,默认为None,即不保留小数

不保留小数
res = round(10.6)
print(res)  # 11

保留小数,保留的最小位四舍五入
res = round(10.567, 2)
print(res)  # 10.57

!!!
如果数字为n.5的时候,n为奇数才会5入,否则后面还要更多的小数位才能是我们理解当中的样子,也就是必须实际的大于.5这个临界值,可以使用标准库decimal处理掉这个问题。
res = round(4.5)
print(res)  # 4
res = round(3.5)
print(res)  # 4

res = round(4.51)
print(res)  # 5
res = round(3.51)
print(res)  # 4

多位小数情况正好相反,只有偶数才会5入
res = round(4.35, 1)
print(res)  # 4.3
res = round(4.45, 1)
print(res)  # 4.5
res = round(4.555, 2)
print(res)  # 4.55
res = round(4.665, 2)
print(res)  # 4.67

计算一个数值的N次幂

语法: pow(parameter1,parameter2,[parameter3])

参数一表示运算数,参数二表示幂次方数,参数三表示被除数,计算幂运算结果除法余数;

还记得python的幂运算符嘛?
res = pow(2, 3)
print(res)        # 8
print(2 * 2 * 2)  # 8
print(2 ** 3)     # 8

除法求余数
res = pow(2, 3, 3)
print(res)    # 2
print(8 % 3)  # 2

计算一个容器(字符串除外)中的数字之和,容器中的数据必须都是数字类型

lst = [1, 2, 3, 4]
res = sum(lst)
print(res)  # 10

max获取序列中的最大值,min获取序列中的最小值,max&min属于高阶函数;

语法: max(parameter1,[parameter2, parameter3, ...],key=None)

参数 说明 parameter1 指定的序列,容器类型数据(包括字符串) parameter2… 多个值,可以是多个参数一,这些值可以是数值或者是序列 key 函数名,容器中的值的计算方式,按照此计算方式返回值,默认为None,即单纯的比数字大小;

不指定key
lst = [0, 1, 2, 3, 4]
res = max(lst)  # 4
res = min(lst)  # 0

多参数
1、参数可以不只一个,但是多个参数必须相同的数据类型,比较参数中的第一个参数返回数据,但是众序列中的第一个参数都必须是相同的数据类型,如果是字符串,比如ABC之间的比较是根据ASCII码进行的。
lst1 = [0, 100]
lst2 = [2, 10]
print(max(lst1, lst2))  # [2, 10]
print(min(lst1, lst2))  # [0, 100]
2、参数可以不是容器类型数据,可以直接比较多个数字(其实也就是元组了)
print(max(1, 2, 3))  # 3
print(min(1, 2, 3))  # 1

指定key,经过key指定的函数处理,比较返回的结果,然后返回对应的数据
lst = [0, 1, 2, 3, 4]

def func(num):
    return num * -1

res = max(lst, key=func)  # 0
print(res)
res = min(lst, key=func)  # 4
print(res)

对一个序列中的值进行排序,默认按照升序(从小到大)排列;数字按照大小排序,ASCII字符串按照编码顺序排序,其余字符的排序规律不清,可能是按照某个指定的编码的先后进行排序。

语法: sorted(parameter1, key=None, reverse=False)

参数 说明 parameter1 指定排序的序列数据 key 指定排序的方法,使用方法和max等一众高阶函数的方法是一样的; reverse 排序方式,默认为False, 即为升序,True为降序;

使用list为例
lst = [2, 0, 1, 3, 4]

默认为升序
new_lst = sorted(lst)
print(new_lst)  # [0, 1, 2, 3, 4]

降序
new_lst = sorted(lst, reverse=True)
print(new_lst)  # [4, 3, 2, 1, 0]

注意和list内置方法的区别,list.sort方法在原数据上重新排序,sorted方法返回一个新的数据;
lst1 = [1, 0, 3]
lst1.sort()
print(lst1)  # [0, 1, 3]

lst2 = [1, 0, 3]
new_lst2 = sorted(lst2)
print(lst2)  # [1, 0, 3]
print(new_lst2)  # [0, 1, 3]

zip & enmerate 见推导式。

还记得如何直接表示一个非十进制数字吗?

  • 0b 开头表示二进制数;
  • 0o 开头表示八进制数;
  • 0h 开头表示十六进制数;
十进制数 转 二进制
res = bin(255)
print(res)  # 0b11111111

八进制 转 二进制
res = bin(0o377)
print(res)  # 0b11111111

十六进制 转 二进制
res = bin(0xff)
print(res)  # 0b11111111

还记得ASCII编码吗?下面的函数可以将ASCII编码中包含的字符在字符和序号之间转换

返回 97 号字符
res = chr(97)
print(res)  # a
res = ord('A')
print(res)  # 65

默认返回当前位置的类、函数、变量。

定义函数
def func():
    pass

定义类
class Class:
    pass

定义变量
var = 1

返回属于当前位置(文件)的类、函数、变量
res = dir()
print(res)  # ['Class', '__annotations__', '__builtins__', '__cached__', '__doc__', '__file__', '__loader__', '__name__', '__package__', '__spec__', 'func', 'var']

def func1():
    inner_var = 1  # 内置变量(属于函数func1)
    print(dir())  # 返回输入当前位置(函数func1)的类、函数、变量
func1()  # ['inner_var']

range 本身不是一个函数,而是一个类,但是在日常的使用过程中经常被作为一个函数使用;

接下的讲解主要当作是一个函数使用去讲解;

语法: range(value, [stop_value,] [step_value])

参数 说明 value 意义为返回的起点数值;但是如果单独使用话本身的含义为0,原本指定的值成为stop_value的值; stop_value 意义为返回数的最大范围,但是终点数不是其本身,如果stop_value是0或者正数,就是stop_value减一,如果stop_value是负数,就是stop_value加一; step_value 步长,每个返回值之间的间隔数,默认为1;

在实际的使用过程中往往配合for循环使用
for i in range(10):
    print(i)

但是此例中因为便于查看不使用for循环演示,而是改用list强转演示;

一个参数:表示返回 0 ~ N-1 的数值
lst = list(range(10))
print(lst)  # [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]

两个参数表示返回 N ~ M-1 的数值
lst = list(range(3, 10))
print(lst)  # [3, 4, 5, 6, 7, 8, 9]

三个参数表示返回 N ~ M-1 的数值,但是每个数间隔F
lst = list(range(3, 10, 2))
print(lst)  # [3, 5, 7, 9]

倒序: 只要让步长变为负数即可,但是也要注意 N 和 M 的数值确保范围准确
lst = list(range(10, -10, -4))
print(lst)  # [10, 6, 2, -2, -6]

上面的方法可以将字符串编译为python代码执行,eval只能适用于简单的代码;exec可以将更加复杂的代码执行;

eval 只能编译简单的代码
char = 'print("Hello MSR.")'
eval(char)  # Hello MSR.

定义变量(eval不能编译,但是exec可以)
char = 'new_char = "My motherland is China."'
eval(char)  # SyntaxError
exec(char)
print(new_char)  # My motherland is China.

将字符串中的转义字符失效,还记得字符串前缀 r吗?他们的效果是一样的,但是repr会将两边的引号也显示出来。

转义
char = 'Hello\nChina.'
print(char)
'''
Hello
China.

'''

原型化
char = repr(char)
print(char)  # 'Hello\nChina.'

repr 和 字符串前缀 r 的不同:显示出两边的引号
print(r'MSR')  # MSR
print(repr('MSR'))  # 'MSR'

将指定数据经过哈希运算法则生成的哈希值返回,相同的两个数据同时经过哈希运算法则得出的结果一定相同,所以一般哈希运算用于文件校验和密码加密等场景;

每次的结果不一定相同,但是相同数据同时运算结果一定相同
hash1 = hash('abs')
hash2 = hash('abs')
print(hash1)
print(hash2)
'''
-4611394003149070947
-4611394003149070947
'''

再上述使用hash()方法的时候,我们发现相同数据在多次运算的时候,结果不一定相同,这是因为控制hash的环境变量 PYTHONHASHSEED所作用的,如果在启动python的时候,设定该环境变量,则可以复现hash值,也就是每次的hash值都是相同的。

示例
不指定PYTHONUNBUFFERED,hash每次都是随机的
python main.py

指定PYTHONUNBUFFERED,hash是固定复现的
PYTHONUNBUFFERED=11 python main.py

查看各种函数、类的帮助文档,还记得如何给自定义函数和类注释帮助文档吗?

类似的功能还有函数的内置方法 __doc__() 可以实现;

查看print方法的帮助文档
print_help = help(print)
print(print_help)
"""
Help on built-in function print in module builtins:

print(...)
    print(value, ..., sep=' ', end='\n', file=sys.stdout, flush=False)

    Prints the values to a stream, or to sys.stdout by default.

    Optional keyword arguments:
    file:  a file-like object (stream); defaults to the current sys.stdout.

    sep:   string inserted between values, default a space.

    end:   string appended after the last value, default a newline.

    flush: whether to forcibly flush the stream.

None
"""

四个数字类型方法和五个容器类型方法,主要用作数据的生成和数据之间的强转;

详情请参见六大数据类型和数据之间的强制转换;

返回一个数据的内存地址,这个地址是唯一的,这个东西关系到了一个程序占据资源空间的大小,也是评判一个程序是否优劣的标准之一,还记得我们之前讲过的Python的缓存机制吗?

char = 'Hello MSR.'
char_id = id(char)
print(char_id)  # 2884357927408

查看一个容器类型数据的长度,也就是一级元素的个数;

lst = [1, 2, 3]
lst_length = len(lst)
print(lst_length)  # 3

列表类型数据还有内置方法 __len__ 也可以查看
lst_length = lst.__len__()
print(lst_length)

一般配合range 遍历容器使用
lst = [1, 2, 3]
for i in range(len(lst)):
    print(lst[i])

type是Python的一个内置类,作用是返回一个数据的类型

char = 123
char_type_obj = type(char)
print(char_type_obj)  #
char_type = char_type_obj.__name__
print(char_type)  # int

判断数据类型
if char_type == 'str':
    print(char)
else:
    print(char_type)

用于判断数据的类型,返回布尔值;

语法: isinstance(x, A_tuple)

参数 说明 x 要判断的数据 A_tuple 要判断的数据类型,如果x是该数据类型返回真,反之为假;也可以是一个元组中包含多个数据类型,如果x的数据类型是元组中的其中之一就返回真,反之返回假;

res = isinstance(100, int)
print(res)  # True

res = isinstance(False, (str, float, tuple))
print(res)  # False

注意:Python中的 布尔型 和 整型 在使用isinstance判断的时候是相同的
res = isinstance(False, (str, int, tuple))
print(res)  # True

用法和 isinstance一模一样,用于判断指定类和类之间是否存在子父关系, isinstanceissubclass的详细用法见 面向对象(类的继承)

详情请见IO文件管理;

用于输出所有的全局变量和局部变量,详情请见函数进阶(全局空间和局部空间)。

用于退出程序,结束程序;

quit()
exit()

常用关键字

引导出系统中所有的关键字
import keyword

print(keyword.kwlist)

关键字 作用 pass 过,占位符;是空语句,本身没有作用,个别情况为了保持程序结构的完整性二占据一些必要的位置; NotImplemented 同”None”; Ellipsis 省略号; … 同”Ellipsis” break 终止循环; continue 跳过当前循环; if…elif..else… if语句; for…in…else… for循环; while…else… while循环; del 删除变量,释放空间; None 基础数据类型,表示空; global 声明全局变量; nonlocal 声明局部变量; def 定义函数; class 定义类; as 别名;

还有许许多多的关键字不在列举;

常见内置属性

print(__name__)   # 当前模块
print(__file__)  # 当前文件路径
print(__doc__)   # 文档注释
print(__package__)  # 位置

Original: https://www.cnblogs.com/msr20666/p/16265393.html
Author: 小小垂髫
Title: python常用内置函数和关键字

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/810442/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • 数据分析总结

    引用: 了解数据 认识数据,知道数据的规模,取值情况,类型等 数据预处理: 为什么要进行数据预处理: 原始数据普遍存在问题,通常为脏数据,必须加以处理才能用于分析,一方面要提高数据…

    Python 2023年10月26日
    039
  • 【Python基础教程】类的定义和使用

    哈喽兄弟们,今天咱们分享一下类的定义和使用。 在Python中,类表示具有相同属性和方法的对象的集合。在使用类时,需要先定义类,然后再创建类的实例,通过类的实例就可以访问类中的属性…

    Python 2023年11月1日
    041
  • 【机器学习】数据准备–python爬虫

    前言 我们在学习机器学习相关内容时,一般是不需要我们自己去爬取数据的,因为很多的算法学习很友好的帮助我们打包好了相关数据,但是这并不代表我们不需要进行学习和了解相关知识。在这里我们…

    Python 2023年11月2日
    041
  • Python3基础教程:return和yield的区别

    一、说明 return一直中,每中语言中其没没有很大差别,就不多说了。(shell语言return的是退出状态,可能差别是比较大的) 最早看到yield应该是哪们语言用来调整什么线…

    Python 2023年5月24日
    0111
  • python包合集-cffi

    cffi是连接Python与c的桥梁,可实现在Python中调用c文件。cffi为c语言的外部接口,在Python中使用该接口可以实现在Python中使用外部c文件的数据结构及函数…

    Python 2023年11月1日
    048
  • MySQL复习大纲

    思维导图大纲 下面我将根据思维导图来复习 MySQL基本数据类型 常见的其实就分为3种:字符串: char[字符型…

    Python 2023年6月10日
    075
  • 【Python】Matplotlib绘制折线图

    文章目录 * – + 1.Matplotlib画图简单实现 + 2.折线图 + * 2.1绘制折线图 * 2.2设置线的格式 * 2.3设置折点 * 2.4.图片的保存…

    Python 2023年8月30日
    066
  • python删除空值多于50%的行_删除Pandas中“空”值超过60%的列

    我有一个这样的数据框:import pandas as pd data = { ‘c1’: [‘Test1′,’Test…

    Python 2023年8月8日
    066
  • 非自交任意多边形与矩形框的交集面积计算方法

    非自交任意多边形与矩形框的交集面积计算方法 1、应用背景 在对象识别的AI计算时,有时需要限定检测区域,即目标对象落在限定区域内有效,在区域外忽略。转换为数学模型为:目标检测框与限…

    Python 2023年10月21日
    040
  • 如何在Jupyter notebook中添加一个conda虚拟环境(在虚拟环境中启动 Jupyter 的方法)

    目录 问题引入 * 错误的例子 创建步骤 * 一、创建虚拟环境 二、进入虚拟环境 三、安装ipykernel库 四、设置jupyter中虚拟环境的显示名称 五、打开jupyter …

    Python 2023年9月8日
    061
  • YOLO系列 — YOLOV7算法(三):YOLO V7算法train.py代码解析

    YOLO系列 — YOLOV7算法(三):YOLO V7算法train.py代码解析 先介绍下每个参数的含义(直接在代码上写吧) parser = argparse.Argumen…

    Python 2023年10月27日
    041
  • CoCo数据集下载

    文章目录 1.介绍 2.下载 * 2.1 官网 2.2 百度网盘 2.3 下载到linux服务器 1.介绍 MS COCO的全称是Microsoft Common Objects …

    Python 2023年9月27日
    044
  • scrapy常用问题

    1、动态加载又对及时性要求很高怎么处理?1,selenium+Phantomjs2,尽量不适用sleep而是用WebDriverWait 2、分布式爬虫主要解决什么问题?1,ip …

    Python 2023年10月5日
    028
  • Python3中的位运算符

    一·位运算符 python中位运算按照数据在内存中的二进制位(Bit)进行操作,它一般用于底层开发(算法设计、驱动、图像处理、单片机等),在应用层开发(Web 开发、Linux 运…

    Python 2023年5月24日
    073
  • [Pandas技巧] 多行合并成一行

    美图欣赏2022/09/16 在最近的需求开发中,有如下需求需要进行修改,数据源demo如下所示 根据字段’material’进行分组,对字段’…

    Python 2023年8月18日
    065
  • 2022深圳杯C题思路解析

    题目描述: 继续更新 再更问题三 继续更新第一问、第四问 1.2 问题重述 在制定电动车调度方案时,必须考虑充、换电池的时间成本,从而提出了新 的车辆运输选址及调度问题。 1) 已…

    Python 2023年8月30日
    037
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球