范文健康探索娱乐情感热点
投稿投诉
热点动态
科技财经
情感日志
励志美文
娱乐时尚
游戏搞笑
探索旅游
历史星座
健康养生
美丽育儿
范文作文
教案论文

68个Python内置函数详解

  内置函数就是Python给你提供的,拿来直接用的函数,比如print.,input等。
  截止到python版本3.6.2 ,python一共提供了68个内置函数,具体如下 abs dict help min setattr
  all dir hex next slice
  any pmod 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大类,正在学习Python基础的读者一定不要错过,建议收藏学习!
  和数字相关1. 数据类型
  bool : 布尔型(True,False)
  int : 整型(整数)
  float : 浮点型(小数)
  complex : 复数
  2. 进制转换
  bin 将给的参数转换成二进制
  otc 将给的参数转换成八进制
  hex 将给的参数转换成十六进制print(bin(10)) # 二进制:0b1010
  print(hex(10)) # 十六进制:0xa
  print(oct(10)) # 八进制:0o12
  3. 数学运算
  abs 返回绝对值
  pmode 返回商和余数
  round 四舍五入
  pow(a, b) 求a的b次幂, 如果有三个参数. 则求完次幂后对第三个数取余
  sum 求和
  min 求最小值
  max 求最大值print(abs(-2)) # 绝对值:2
  print(pmod(20,3)) # 求商和余数:(6,2)
  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,9,12,7,2)) #求最小值:2
  print(max(7,3,15,9,4,13)) #求最大值:15
  和数据结构相关1. 序列
  (1)列表和元组
  list 将一个可迭代对象转换成列表
  tuple 将一个可迭代对象转换成元组print(list((1,2,3,4,5,6))) #[1, 2, 3, 4, 5, 6]
  print(tuple([1,2,3,4,5,6])) #(1, 2, 3, 4, 5, 6)
  (2)相关内置函数
  reversed 将一个序列翻转, 返回翻转序列的迭代器
  slice 列表的切片lst = "你好啊"
  it = reversed(lst) # 不会改变原列表. 返回一个迭代器, 设计上的一个规则
  print(list(it)) #["啊", "好", "你"]
  lst = [1, 2, 3, 4, 5, 6, 7]
  print(lst[1:3:1]) #[2,3]
  s = slice(1, 3, 1) # 切片用的
  print(lst[s]) #[2,3]
  (3)字符串
  str 将数据转化成字符串print(str(123)+"456") #123456
  format 与具体数据相关, 用于计算各种小数, 精算等.
  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, "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(123456789, "0.2E" )) # 科学计数法. 保留2位小数(大写):1.23E+08
  print(format(1.23456789, "f" )) # 小数点计数法. 保留6位小数:1.234568
  print(format(1.23456789, "0.2f" )) # 小数点计数法. 保留2位小数:1.23
  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"ä» å å é äº å "
  bytearray 返回一个新字节数组. 这个数字的元素是可变的, 并且每个元素的值得范围是[0,256)
  ret = bytearray("alex" ,encoding ="utf-8")
  print(ret[0]) #97
  print(ret) #bytearray(b"alex")
  ret[0] = 65 #把65的位置A赋值给ret[0]
  print(str(ret)) #bytearray(b"Alex")
  ord 输入字符找带字符编码的位置
  chr 输入位置数字找出对应的字符
  ascii 是ascii码中的返回该值 不是就返回uprint(ord("a")) # 字母a在编码表中的码位:97
  print(ord("中")) # "中"字在编码表中的位置:20013
  print(chr(65)) # 已知码位,求字符是什么:A
  print(chr(19999)) #丟
  for i in range(65536): #打印出0到65535的字符
  print(chr(i), end=" ")
  print(ascii("@")) #"@"
  repr 返回一个对象的string形式s = "今天 吃了%s顿	饭" % 3
  print(s)#今天# 吃了3顿 饭
  print(repr(s)) # 原样输出,过滤掉转义字符   	 r 不管百分号%
  #"今天 吃了3顿	饭"
  2. 数据集合
  字典:dict 创建一个字典
  集合:set 创建一个集合
  frozenset 创建一个冻结的集合,冻结的集合不能进行添加和删除操作。
  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]
  lst.sort # sort是list里面的一个方法
  print(lst) #[1, 5, 5, 6, 7, 9, 12, 13, 18]
  ll = sorted(lst) # 内置函数. 返回给你一个新列表 新列表是被排序的
  print(ll) #[1, 5, 5, 6, 7, 9, 12, 13, 18]
  l2 = sorted(lst,reverse=True) #倒序
  print(l2) #[18, 13, 12, 9, 7, 6, 5, 5, 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 获取集合的枚举对象lst = ["one","two","three","four","five"]
  for index, el in enumerate(lst,1): # 把索引和元素一起获取,索引默认从0开始. 可以更改
  print(index)
  print(el)
  # 1
  # one
  # 2
  # two
  # 3
  # three
  # 4
  # four
  # 5
  # five
  all 可迭代对象中全部是True, 结果才是True
  any 可迭代对象中有一个是True, 结果就是Trueprint(all([1,"hello",True,9])) #True
  print(any([0,0,0,False,1,"good"])) #True
  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 = filter(func, lst) #l1是迭代器
  print(l1) #
  print(list(l1)) #[1, 3, 5, 7, 9]
  map 会根据提供的函数对指定序列列做映射(lamda)
  语法 : map(function, iterable)
  可以对可迭代对象中的每一个元素进行映射. 分别去执行 functiondef f(i): return i
  lst = [1,2,3,4,5,6,7,]
  it = map(f, lst) # 把可迭代对象中的每一个元素传递给前面的函数进行处理. 处理的结果会返回成迭代器print(list(it)) #[1, 2, 3, 4, 5, 6, 7]
  和作用域相关
  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__": , "__file__": "D:/pycharm/练习/week03/new14.py", "__cached__": None,
  # "func": }
  # 今天内容很多
  和迭代器生成器相关
  range 生成数据
  next 迭代器向下执行一次, 内部实际使 用了__ next__ 方法返回迭代器的下一个项目
  iter 获取迭代器, 内部实际使用的是__ iter__ 方法来获取迭代器for i in range(15,-1,-5):
  print(i)
  # 15
  # 10
  # 5
  # 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进行求值s1 = input("请输入a+b:") #输入:8+9
  print(eval(s1)) # 17 可以动态的执行代码. 代码必须有返回值
  s2 = "for i in range(5): print(i)"
  a = exec(s2) # exec 执行代码不返回任何内容
  # 0
  # 1
  # 2
  # 3
  # 4
  print(a) #None
  # 动态执行代码
  exec("""
  def func:
  print(" 我是周杰伦")
  """ )
  func #我是周杰伦
  code1 = "for i in range(3): print(i)"
  com = compile(code1, "", mode="exec") # compile并不会执行你的代码.只是编译
  exec(com) # 执行编译的结果
  # 0
  # 1
  # 2
  code2 = "5+6+7"
  com2 = compile(code2, "", mode="eval")
  print(eval(com2)) # 18
  code3 = "name = input("请输入你的名字:")" #输入:hello
  com3 = compile(code3, "", mode="single")
  exec(com3)
  print(name) #hello
  输入输出
  print : 打印输出
  input : 获取用户输出的内容print("hello", "world", sep="*", end="@") # sep:打印出的内容用什么连接,end:以什么为结尾
  #hello*world@
  内存相关
  hash : 获取到对象的哈希值(int, str, bool, tuple). hash算法:(1) 目的是唯一性 (2) dict 查找效率非常高, hash表.用空间换的时间 比较耗费内存s = "alex"print(hash(s)) #-168324845050430382lst = [1, 2, 3, 4, 5]print(hash(lst)) #报错,列表是不可哈希的 id : 获取到对象的内存地址s = "alex"print(id(s)) #2278345368944
  文件操作相关
  open : 用于打开一个文件, 创建一个文件句柄f = open("file",mode="r",encoding="utf-8")
  f.read
  f.close
  模块相关
  __ import__ : 用于动态加载类和函数# 让用户输入一个要导入的模块
  import os
  name = input("请输入你要导入的模块:")
  __import__(name) # 可以动态导入模块
  帮 助
  help : 函数用于查看函数或模块用途的详细说明print(help(str)) #查看字符串的用途
  调用相关
  callable : 用于检查一个对象是否是可调用的. 如果返回True, object有可能调用失败, 但如果返回False. 那调用绝对不会成功a = 10
  print(callable(a)) #False 变量a不能被调用
  #
  def f:
  print("hello")
  print(callable(f)) # True 函数是可以被调用的
  查看内置属性
  dir : 查看对象的内置属性, 访问的是对象中的__dir__方法print(dir(tuple)) #查看元组的方法

港股早知道比亚迪在自动驾驶领域不断发力荣耀CEO称今年折叠屏手机市场将增长10倍全球市场美东时间周三,美联储主席鲍威尔表示倾向于支持3月份加息25个基点,美股三大指数全线收涨,截止收盘,道指上涨596。40点,收报33891。35点,涨幅1。79纳指上涨219OPPO良心出击,天玑81005000mAh新机备货,12256G定下2599与往年相比,今年的旗舰机发机速度和数量都太夸张了,并且在配置上也都大同小异,这对于想要入手4nm新机的朋友来说选择困难症又犯了。但或许中端市场要更有看头一些,堆料一款更比一款惊人。微信越来越像一个操作系统,这种变化好吗?微信目前的趋势是在往一个自主的OS方向发展,这一点从微信即将发布的PC端2。7。0版本可以看出来,以前在电脑上用微信,当收到一个小程序时,微信会提示我们去手机端查看,但是在新版本中有哪一款学生不能玩游戏的智能手机,大家推荐一下?据我所知,没有哪一款不能让儿童玩戏的手机。最好的办法1。不下载安装游戏软件。2。正确引导儿童,讲清道理。凡智能手机,制造商为满足更多用户需求,必会集更多功能于一机,除非买只能发短信微信发图片要收钱,这是真的吗?微信发图片要收钱是不可能的,为什么这么说我来给你们分析第一微信的用户已经8亿多人使用,相同的聊天软件阿里钉钉,陌陌和别的聊天软件的用户增长都不强,原因就是使用微信的人太多了,如果微为什么很多人以为科学无国界,爱情无国界,真的没国界吗?爱情无国界,是荷尔蒙惹的祸!这是真的无国界,要不现在纯种族的国家已经很少了,世界将来必定是混血的世界!科学无国界,在理论上是成立的。任何一个国家都拥有出大科学家的条件,大科学家必定新能源领域中估值即将修复的龙头公司及具有爆发潜力的人气高标前天和昨天魔女在文章里都说了,重大会议预期这两天会炒起来,昨天给朋友们分享的三胎和养老,今天的市场行情走势也再次验证了魔女的逻辑,这篇文章魔女继续给朋友们分享重大会议预期的第二个方消息称朴道征信将承接原厚植征信相关业务中国网财经3月2日(记者安然朱玲)小米原来通过厚植征信开展的征信业务,或将全部由朴道征信承接。近日,财新援引一位接近小米人士的消息称,此前由厚植征信为天星数科提供企业征信服务随着小福特发布重组计划电动汽车业务独立运营,未来将独立上市?21世纪经济报道记者杜巧梅报道在2021年成为仅次于特斯拉的美国第二大电动汽车生产商之后,福特汽车正在加速其电动化转型步伐。北京时间3月2日晚,福特汽车对外宣布成立独立运营的电动汽担心电动车电池衰减?46万公里的特斯拉告诉你答案当下是电动汽车正火爆的时候,不用交购置税,甚至在某些地区送不限行车牌的政策,让很多不考虑电车的人也开始接受它。不过相信大家和我一样有个问题,那就是,电动汽车的电池的衰减程度到底有多荣耀X10,我心中最完美的中端机荣耀X10发布于2020年5月20日,到现在快两年了,从购买到现在,我一直把它当主力机使用。期间也换了两个手机。一个是荣耀V40,不过它不能升级鸿蒙2。0,而且容易发烫,我就把它退
弯道超车正在开始,台积电也落后一步,芯片行业将迎变革提到芯片巨头,很多人第一时间都会想到苹果华为和高通。因为这几家巨头设计的芯片性能强悍,每年都能带给消费者新的体验。虽说这几家巨头企业都有着顶尖的设计能力,但如果想要让设计的芯片铺货固态电池,新能源汽车行业下一高地?本报记者刘旭颖在新能源汽车赛道,固态电池正成为新宠。今年1月9日,蔚来高调发布了能量密度达360Whkg的150kWh固态电池包以及搭载该电池包续航将超1000km的蔚来ET7轿车董明珠称手机行业需要颠覆或是鸿蒙给她自信百姓家电网原创一直以语出惊人出名的格力总裁董明珠,最近又对手机行业的发展发表了一些看法,而这次的一番说话,却让人觉得是意有所指。在7月6日举行的2021中国新消费品牌增长峰会上,董苏宁易购混改方案落地深圳国资退出,江苏国资牵手接盘图片来源网络7月5日晚间,苏宁易购发布公告称,公司控股股东实际控制人张近东先生及其一致行动人苏宁控股集团,公司持股5以上股东苏宁电器集团,西藏信托(以下合称转让方)拟将所持公司合计安兔兔发布用户偏好榜,你的每一个习惯,大数据都知道安兔兔发布2021年第二季度用户偏好榜,根据大数据细化智能手机各项数据,分析用户手机屏幕尺寸分辨率刷新率处理器内存等各项数据信息,基于安兔兔庞大的平台用户数量,因此最终得出的数据结轻薄本当道!复盘MAXCCC笔记本电脑的走红之路伴随着人们对电脑需求的不断变化,笔记本电脑也有了更多的类型,但高性价比却始终是大多数人追求看重的关键一点,而2021年最值得期待的笔记本电脑中,时光机Max笔记本电脑作为一匹黑马,深受其害的消费者可以名正言顺地去告苹果了近日,苹果iPhone手机的防水广告又惹事了,看广告上iPhone手机的防水功能太好了,手机不小心弄脏了,是可以直接用水龙头冲洗的。有些使用iPhone手机的年轻人模仿能力很强,又确定!新MacBookPro采用M1X处理器,M2则要到明年据国外爆料者Dylandkt消息,已确定新款MacBookPro会采用M1X处理器,今年肯定发布。到了明年,苹果将发布新工艺的M2,届时MacBookAir将迎来更新,但他表示功能14年固态品牌工厂金胜维出品,2TBmSATASSD上手体验mSATA固态硬盘最初只是用在一些工业装置上,随着笔记本电脑平板电脑的轻薄化发展,有一段时期很多本本增加了mSATA接口,这个接口在现在新出的本本上基本上已经看不到了,只有一些移动哪些牌子的蓝牙耳机口碑好,这几个牌子的蓝牙耳机口碑好且实用蓝牙耳机嘛,讲究的就是方便携带小巧轻盈嘛。今天呢,我主要给大家分享几款我觉得很好且很实用的蓝牙耳机。对于爱听歌追剧的小伙伴是可以完全驾驭的了的神仙蓝牙耳机。音质上真的也是秒杀同价位都有什么适合运动跑步用的平价无线蓝牙耳机?2021跑步耳机推荐从事蓝牙耳机行业已经几年的时间,还是比较清楚其中的弯弯绕绕,很多行外人总是喜欢要行内人士来推荐无线蓝牙耳机,因为圈内人士对蓝牙耳机无疑是了解最多的。今天要给大家分享的就是几款适合运