【Python学习笔记】第十八节 Python 内置函数

news2025/1/10 13:03:10

Python 内置函数

内置函数就是Python给你提供的, 拿来直接用的函数,比如print,input等


Python 内置函数一览表

内置函数

abs()

divmod()

input()

open()

staticmethod()

all()

enumerate()

int()

ord()

str()

any()

eval()

isinstance()

pow()

sum()

basestring()

execfile()

issubclass()

print()

super()

bin()

file()

iter()

property()

tuple()

bool()

filter()

len()

range()

type()

bytearray()

float()

list()

raw_input()

unichr()

callable()

format()

locals()

reduce()

unicode()

chr()

frozenset()

long()

reload()

vars()

classmethod()

getattr()

map()

repr()

xrange()

cmp()

globals()

max()

reverse()

zip()

compile()

hasattr()

memoryview()

round()

__import__()

complex()

hash()

min()

set()

delattr()

help()

next()

setattr()

dict()

hex()

object()

slice()

dir()

id()

oct()

sorted()

exec 内置表达式

下面给大家介绍常用的内置函数

一、和数字相关

1、进制转换

  • bin() 将给的参数转换成二进制

  • oct() 将给的参数转换成八进制

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

# coding=utf-8

print(bin(10))  # 二进制:0b1010
print(hex(10))  # 十六进制:0xa
print(oct(10))  # 八进制:0o12

2、数学运算

  • abs() 返回绝对值

  • divmode() 返回商和余数

  • round() 四舍五入

  • pow(a, b) 求a的b次幂, 如果有三个参数. 则求完次幂后对第三个数取余

  • sum() 求和

  • min() 求最小值

  • max() 求最大值

# coding=utf-8

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

二、和数据结构相关

1、列表和元组

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

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

# coding=utf-8

print(list((1, 2, 3, 4, 5)))  # [1, 2, 3, 4, 5]
print(tuple([1, 2, 3, 4, 5]))  # (1, 2, 3, 4, 5)
  • reversed() 将一个序列翻转, 返回翻转序列的迭代器

  • slice() 列表的切片

# coding=utf-8

lst = "你好啊许多钱"
it = reversed(lst)  # 不会改变原列表. 返回一个迭代器, 设计上的一个规则
print(list(it))  # ['钱', '多', '许', '啊', '好', '你']
lst = [1, 2, 3, 4, 5, 6, 7, 8, 9]
print(lst[2:5:1])  # [2,3]
s = slice(2, 5, 1)  # 切片用的
print(lst[s])  # [2,3]

2、字符串

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

print(str(hello)+' world')  #hello world
  • format() 与具体数据相关, 用于计算各种小数, 精算等.

# coding=utf-8

s = "hello world!"
print(format(s, "^20"))  # 剧中
print(format(s, "<20"))  # 左对齐
print(format(s, ">20"))  # 右对齐
#     hello world!
# hello world!
#         hello world!
print(format(3, 'b'))  # 二进制:11
print(format(97, 'c'))  # 转换成unicode字符:a
print(format(11, 'd'))  # ⼗进制:11
print(format(11, 'o'))  # 八进制:13 
print(format(11, 'x'))  # 十六进制(⼩写字母):b
print(format(11, 'n'))  # 和d⼀样:11
print(format(11))  # 和d⼀样:11
print(format(123456789, 'e'))  # 科学计数法. 默认保留6位小数:1.234568e+08
print(format(123456789, '0.2E'))  # 科学计数法. 保留2位小数(大写):1.23E+08
print(format(1.23456789, 'f'))  # 小数点计数法. 保留6位小数:1.234568
print(format(1.23456789, '0.10f'))  # 小数点计数法. 保留10位小数:1.2345678900
print(format(1.23456789e+3, 'F'))  # 小数点计数法. 很大的时候输出INF:1234.567890
  • bytes() 把字符串转化成bytes类型

bs = bytes("你好", encoding="utf-8")
print(bs)  # b'\xe4\xbd\xa0\xe5\xa5\xbd'
  • bytearray() 返回一个新字节数组. 这个数字的元素是可变的, 并且每个元素的值得范围是[0,256)

ret = bytearray("helly", encoding='utf-8')
print(ret[0])  # 104
print(ret)  # bytearray(b'helly')
ret[0] = 65  # 把65的位置A赋值给ret[0]
print(str(ret))  # bytearray(b'Aelly')
  • ord() 输入字符找带字符编码的位置

  • chr() 输入位置数字找出对应的字符

  • ascii() 是ascii码中的返回该值 不是就返回u

# coding=utf-8

print(ord('a'))  # 字母a在编码表中的码位:97
print(ord('我'))  # '中'字在编码表中的位置:25105
print(chr(65))  # 已知码位,求字符是什么:A
print(chr(19999))  # 丟

for i in range(100):  # 100
    print(chr(i), end=" ")

print(ascii("@"))  # '@'
  • repr() 返回一个对象的string形式

s = "今天\n吃了%s顿\t饭" % 3
print(s)  # 今天# 吃了3顿    饭
print(repr(s))  # 原样输出,过滤掉转义字符 \n \t \r 不管百分号%
# '今天\n吃了3顿\t饭'

3、数据集合

  • 字典:dict 创建一个字典

  • 集合:set 创建一个集合

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

4、相关内置函数

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

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

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

  • Iterable: 可迭代对象

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

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

# coding=utf-8

lst = [3, -1, 6, 90, 1, 28, 0, 5, 8]
lst.sort()  # sort是list里面的一个方法
print(lst)  # [-1, 0, 1, 3, 5, 6, 8, 28, 90]

ll = sorted(lst)  # 内置函数. 返回给你一个新列表  新列表是被排序的
print(ll)  # [-1, 0, 1, 3, 5, 6, 8, 28, 90]

l2 = sorted(lst, reverse=True)  # 倒序
print(l2)  # [90, 28, 8, 6, 5, 3, 1, 0, -1]

# 根据字符串长度给列表排序
lst = ['one', 'two', 'three', 'four', 'five', 'six']


def f(s):
    return len(s)


l1 = sorted(lst, key=f, )
print(l1)  # ['one', 'two', 'six', 'four', 'five', 'three']

  • enumerate() 获取集合的枚举对象

# coding=utf-8


# 根据字符串长度给列表排序
lst = ['one', 'two', 'three', 'four', 'five', 'six']

for index, el in enumerate(lst, 1):  # 把索引和元素一起获取,索引默认从0开始. 可以更改
    print(index)
    print(el)
  • zip() 函数用于将可迭代的对象作为参数, 将对象中对应的元素打包成一个元组, 然后返回由这些元组组成的列表. 如果各个迭代器的元素个数不一致, 则返回列表长度与最短的对象相同

# coding=utf-8

lst1 = [1, 2, 3, 4]
lst2 = ['龙华', '美兰', '琼山', '秀英']
print(zip(lst1, lst1))  # <zip object at 0x000001751BDC1240>
for el in zip(lst1, lst2):
    print(el)

三、和作用域相关

  • locals() 返回当前作用域中的名字

  • globals() 返回全局作用域中的名字

# coding=utf-8

def func():
    a = 100
    print(locals())  # 当前作用域中的内容
    print(globals())  # 全局作用域中的内容
    print("hello")


func()

四、和迭代器生成器相关

  • range() 生成数据

  • next() 迭代器向下执行一次, 内部实际使用了__ next__()方法返回迭代器的下一个项目

  • iter() 获取迭代器, 内部实际使用的是__ iter__()方法来获取迭代器

# coding=utf-8

for i in range(20, -1, -5):
    print(i)
# 20
# 15
# 10
# 0
lst = [1, 2, 3, 4, 5]
it = iter(lst)  # __iter__()获得迭代器
print(it.__next__())  # 1
print(next(it))  # 2  __next__()
print(next(it))  # 3
print(next(it))  # 4

五、字符串类型代码的执行

  • eval() 执行字符串类型的代码. 并返回最终结果

  • exec() 执行字符串类型的代码

  • compile() 将字符串类型的代码编码. 代码对象能够通过exec语句来执行或者eval()进行求值

# coding=utf-8

s1 = input("请输入a+b:")  # 输入:10+5
print(eval(s1))  # 15 可以动态的执行代码. 代码必须有返回值
s2 = "for i in range(5): print(i)"
a = exec(s2)  # exec 执行代码不返回任何内容

print(a)  # None


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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/374124.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

ARMv8 同步和信号量(读写一致性问题):Load-Exclusive/Store-Exclusive指令详解

目录 一&#xff0c;Local Monitor 与 Global Monitor 1&#xff0c;Local Monitor 2&#xff0c;Global Monitor 二&#xff0c;Exclusive 指令的简单使用 三&#xff0c;Exclusive 示例程序 1&#xff0c;原子自加1程序 2&#xff0c;原子锁程序 四&#xff0c; 多处理…

算法设计与智能计算 || 专题一: 算法基础

专题一: 算法基础 文章目录专题一: 算法基础1. 算法的定义及特点1.1 算法的基本特征1.2 算法的基本要素1.3 算法的评定2 算法常见执行方法2.1 判断语句2.2 循环语句2.3 综合运用3. 计算复杂度4. 代码的重用5. 类函数的定义与使用5.1 定义类5.2 调用类函数1. 算法的定义及特点 …

_hand-2

实现一个迷你版的vue 入口 // js/vue.js class Vue {constructor (options) {// 1. 通过属性保存选项的数据this.$options options || {}this.$data options.data || {}this.$el typeof options.el string ? document.querySelector(options.el) : options.el// 2. 把da…

php mysql高校田径运动会成绩管理系统

第一章 引言 1 1.1 选题背景 1 1.2 编写目的 2 1.3 目标 2 1.4 功能需求 3 第二章 开发工具介绍 4 2.1 PHP 4 2.2 APACHE 5 2.3 MYSQL数据库 5 2.4 运行环境 WINDOWS XP 6 2.5 XAMPP 6 2.6 DREAMWEAVE8 6 2.7 EDITPLUS 7 第三章 需求…

【华为OD机试模拟题】用 C++ 实现 - 热点网络统计(2023.Q1)

最近更新的博客 【华为OD机试模拟题】用 C++ 实现 - 去重求和(2023.Q1) 文章目录 最近更新的博客使用说明热点网络统计【华为OD机试模拟题】题目输入输出描述示例一输入输出示例二输入输出Code使用说明 参加华为od机试,一定要注意不要完全背诵代码,需要理解之后模仿写出…

C++入门知识【超详解】

目录1.认识Chello worldC关键字2.命名空间3.std标准库4.输入输出5.缺省参数6.函数重载7.引用7.1引用的概念7.2引用的场景1.作参数2.作返回值7.3引用的注意点7.4指针和引用的区别8.auto关键字9.基于范围的for循环10.内联函数10.1概念10.2特征11. C98中的指针空值1.认识C hello …

数据结构——单链表(上)

&#x1f307;个人主页&#xff1a;_麦麦_ &#x1f4da;今日名言&#xff1a;“生活总是让我们遍体鳞伤&#xff0c;但到后来&#xff0c;那些受伤的地方一定会变成我们最强壮的地方。” ——海明威《永别了武器》 目录 ​编辑 一、前言 二、正言 3.1链表的概念及结构…

HMM(隐马尔科夫模型)-理论补充2

目录 一.大数定理 二.监督学习方法 1.初始概率 2.转移概率 3.观测概率 三.Baum-Welch算法 1.EM算法整体框架 2. Baum-Welch算法 3.EM过程 4.极大化 5.初始状态概率 6.转移概率和观测概率 四.预测算法 1.预测的近似算法 2.Viterbi算法 1.定义 2. 递推&#xff1…

倒计时2天:中国工程院院士谭建荣等嘉宾确认出席,“警务+”时代来临...

近日伴随公安部、科技部联合印发通知&#xff0c;部署推进科技兴警三年行动计划&#xff08;2023-2025年&#xff09;&#xff0c;现代科技手段与警务工作相结合的方式&#xff0c;正式被定义为未来警务发展的新趋势。 21世纪以来&#xff0c;随着科技的不断发展和创新&#xf…

硬间隔支持向量机算法、软间隔支持向量机算法、非线性支持向量机算法详细介绍及其原理详解

相关文章 K近邻算法和KD树详细介绍及其原理详解朴素贝叶斯算法和拉普拉斯平滑详细介绍及其原理详解决策树算法和CART决策树算法详细介绍及其原理详解线性回归算法和逻辑斯谛回归算法详细介绍及其原理详解硬间隔支持向量机算法、软间隔支持向量机算法、非线性支持向量机算法详细…

JavaScript Date 日期对象实例合集

文章目录JavaScript Date 日期对象实例合集一&#xff0c;使用 Date() 方法获得当日的日期二&#xff0c;使用 getFullYear() 获取年份三&#xff0c;使用getTime() 返回从 1970 年 1 月 1 日至今的毫秒数四&#xff0c;如何使用 setFullYear() 设置具体的日期五&#xff0c;使…

小兔鲜注册页面验证、阶段案例(登录、首页页面)(重点)、小兔鲜放大镜效果——DOM

目录 1. 小兔鲜注册页面验证 2. 阶段案例&#xff08;登录、首页页面&#xff09;&#xff08;重点&#xff09; 3. 小兔鲜放大镜效果 1. 小兔鲜注册页面验证 验证码模块有个小问题&#xff1a; 连续点击获取验证码会导致触发多次计时器&#xff0c;会导致计时出现问题&…

【Stata】从入门到精通.零基础小白必学的教程,一学就fei

视频教程移步&#xff1a;https://www.bilibili.com/video/BV1hK4y1d714/?p4&spm_id_frompageDriver&vd_sourcecc8074e9c81a225f214226065db53d32P3 第二讲 Stata处理数据全流程&#xff08;上&#xff09; P3 - 01:37&#xfeff;内置数据 file example datasets使用…

FastDFS - 分布式文件存储系统

目录一、分布式文件存储1.分布式文件存储的由来2.常见的分布式存储框架二、FastDFS介绍三、FastDFS安装1.拉取镜像文件2.构建Tracker服务3.构建Storage服务4.测试图片上传四、客户端操作1.Fastdfs-java-client1.1 文件上传1.2 文件下载2.SpringBoot整合一、分布式文件存储 1.分…

【MySQL】什么是意向锁 IS IX 及值得学习的思想

文章目录前言行锁和表锁使用意向锁意向锁的算法意向锁的思想JDK 中相似的思想前言 之前看 MySQL 都刻意忽略掉了 IS 和 IX 锁&#xff0c;今天看 《MySQL 是怎样运行的》&#xff0c;把意向锁讲的很通透&#xff0c;本篇博文提炼一下思想。 I: Intention Lock&#xff08;意向…

自建服务器系列-0元搭建linux服务器(windows笔记本)

0元搭建linux服务器一.windows装Centos71.1 centos7 iso镜像1.2 准备U盘1.3 UltraISO 启动盘制作工具安装1.4 准备一台windows 机器1.5 安装过程二 、连接无线wifi三、固定wifi ip3.1 查看网络状态3.2 查看DNS3.3 查看GATEWAY3.4 设置静态IP四、一键快速安装单机版k8s五、申请域…

游戏高度可配置化:通用数据引擎(data-e)及其在模块化游戏开发中的应用构想图解

游戏高度可配置化&#xff1a;通数据引擎在模块化游戏开发中的应用构想图解 ygluu 码客 卢益贵 目录 一、前言 二、模块化与插件 1、常规模块化 2、插件式模块化&#xff08;插件开发&#xff09; 三、通用数据引擎理论与构成 1、名字系统&#xff08;数据类型&#xf…

数据结构与算法之树结构基础

目录为什么要使用树结构树结构基本概念树的种类树的存储与表示常见的一些树的应用场景为什么要使用树结构 线性结构中不论是数组还是链表&#xff0c;他们都存在着诟病&#xff1b;比如查找某个数必须从头开始查&#xff0c;消耗较多的时间。使用树结构&#xff0c;在插入和查…

58-59-60 - 动态内存分配的实现

---- 整理自狄泰软件唐佐林老师课程 文章目录1. 讨论2. 动态内存管理2.1 动态内存管理的关键2.2 动态内存管理的分类3. 定长内存管理的设计与实现3.1 空间划分3.2 内存申请和归还3.3 关键数据类型3.4 思考4. 变长内存管理的设计与实现4.1 空间划分4.2 内存申请和归还4.3 关键数…

802.11 MCS 的最低SNR分析

常常看到这样的表格: 那么这个SNR如何而来? 看看RSSI和SNR的关系,它们之间隔了一个noise floor。从表格看得出,这个底噪在-80~-90之间。 而SNR的核心,也有类似的原因,它和BER有关。