内置函数

内置函数就是在系统安装完python解释器时,由python解释器给提供好的函数

range() 函数

如果你确实需要遍历一个数字序列,内置函数 range() 会派上用场。它生成算术级数

  1. range()函数
  2. 功能:能够生成一个指定的数字序列
  3. 参数:
  4. start : 开始的值 ,默认值为0
  5. stop 结束的值
  6. [, step]: 可选,步进值 默认值为1
  7. 返回值: 可迭代的对象,数字序列

使用案例:

  1. #range函数的使用方式
  2. # 只写一个参数,就是从零开始到10之前,9
  3. # res = range(11)
  4. # 两个参数时,第一个参数是开始的值,第二个参数是结束的值(在结束值之前)
  5. # res = range(5,10)
  6. # 三个参数, 参数1是开始值,参数2是结束值,参数三是步进值
  7. # res = range(1,10,3)
  8. # 获取一个倒叙的数字序列
  9. # res = range(10,0,-1)
  10. # res = range(10,0,-2)
  11. res = range(-10,-20,-1)
  12. res = range(-20,-10)
  13. res = range(-10,10)
  14. print(list(res))

提取range()函数返回的数字序列的方法:

  1. # 获取range函数返回的数字序列的方法
  2. # res = range(10)
  3. # 1。转为list列表数据
  4. # print(list(res))
  5. # 2。通过 for循环 进行遍历
  6. # for i in res:
  7. # print(i)
  8. # 3。转为迭代器,使用next函数调用
  9. # res = iter(res)
  10. # print(next(res))
  11. # print(next(res))

zip() 函数

  1. zip()
  2. 功能:zip 函数是可以接受多个可迭代的对象,然后把每个可迭代对象中的第i个元素组合在一起,形成一个新的迭代器
  3. 参数:*iterables,任意个的 可迭代对象
  4. 返回值: 返回一个元组的迭代器

示例:

  1. var1 = '1234'
  2. var2 = ['a','b','c']
  3. var3 = ('A','B','C','D')
  4. # 调用zip函数,组成新的元组迭代器
  5. res = zip(var1,var2,var3)
  6. # print(res,type(res))
  7. for i in res:
  8. print(i)
  9. '''
  10. ('1', 'a', 'A')
  11. ('2', 'b', 'B')
  12. ('3', 'c', 'C')
  13. ('4', 'd', 'D')
  14. '''
  15. # zip() 与 * 运算符相结合可以用来拆解一个列表:
  16. x = [1, 2, 3]
  17. y = [4, 5, 6]
  18. zipped = zip(x, y)
  19. print(list(zipped))
  20. print(zip(x, y)) # 迭代器对象,
  21. print(*zip(x, y))# 组合好的多个元组数据

其它内置函数

数据类型转换相关内置函数

  • int() 将其它类型数据转为整型
  • float() 转为浮点类型
  • bool() 转为布尔类型
  • complex() 转为复数
  • str() 转为字符串类型
  • list 转为列表类型
  • tuple 转为元组类型
  • dict 转为字典类型
  • set 转为集合类型

变量相关函数

  • id() 获取当前数据的ID标识
  • type() 获取当前数据的类型字符串
  • print() 数据的打印
  • input() 获取输入的数据
  • isinstance() 检测是否为指定的数据类型

数学相关函数

  1. # 数学相关函数
  2. # 获取一个数的绝对值
  3. # print(abs(-99.99))
  4. # 求和 从 start 开始自左向右对 iterable 中的项求和并返回总计值
  5. # print(sum([1,2,3]))
  6. # 获取最大值
  7. # print(max([1,2,3]))
  8. # print(max(99,12,45))
  9. # 获取最小值
  10. # print(min([2,1,6,-9]))
  11. # print(min(6,7,1,0,-2))
  12. # 幂运算 返回 x 的 y 次幂
  13. # print(pow(2,3))
  14. # 四舍五入
  15. # r = round(3.1415926)
  16. # r = round(3.1415926,2) # 小数点保留几位
  17. # r = round(4.5) # 奇进偶退 1.5 = 2 2.5=2,3.5=4,4.5=4
  18. # print(r)

进制相关函数

  1. # bin() 将数值类型转为二进制
  2. # print(bin(123)) # 0b1111011
  3. # int() 将二进制转为整型
  4. # print(int(0b1111011)) #1 23
  5. # oct() 转为八进制数 01234567
  6. # print(oct(123)) # 0o173
  7. # hex() 转为十六进制数 0123456789abcdef
  8. # print(hex(123)) # 0x7b

Ascii码及字符集

  • Ascii 共计 128个字符,更新于 1986年 主要用于显示现代英语和其他西欧语言。
  • GB2312-80 是 1980 年制定的中国汉字编码国家标准。共收录 7445 个字符,其中汉字 6763 个。
  • GBK 于1995年制定 收录了 21003 个汉字。GBK向下与 GB 2312 编码兼容,
  • GBK18030 2001年的1月正式强制执行,是我国制订的以汉字为主并包含多种我国少数民族文字(如藏、蒙古、傣、彝、朝鲜、维吾尔文等)的超大型中文编码字符集强制性标准,其中收入汉字70000余
  • Unicode(统一码、万国码、单一码)是计算机科学领域里的一项业界标准,包括字符集、编码方案等。
    • 它为每种语言中的每个字符设定了统一并且唯一的二进制编码,以满足跨语言、跨平台进行文本转换、处理的要求。1990年开始研发,1994年正式公布。
    • UTF-8 以字节为单位对Unicode进行编码。
  1. # 将字符转为 ascii
  2. r = ord('a')
  3. print(r)
  4. # 将ascii转为字符
  5. r = chr(65)
  6. print(r)

高阶函数

sorted(iterable,[reverse,key])

  1. sorted()
  2. 运行原理:
  3. 把可迭代数据里面的元素,一个一个的取出来,放到key这个函数中进行处理,
  4. 并按照函数中return的结果进行排序,返回一个新的列表
  5. 功能: 排序
  6. 参数:
  7. iterable 可迭代的数据 (容器类型数据,range数据序列,迭代器)
  8. reverse 可选,是否反转,默认为False,不反转, True反转
  9. key 可选, 函数,可以是自定义函数,也可以是内置函数
  10. 返回值: 排序后的结果

示例:

  1. arr = [3,7,1,-9,20,10]
  2. # 默认按照从小到大的方式进行排序
  3. # res = sorted(arr) # [-9, 1, 3, 7, 10, 20]
  4. # 可以按照从大到小的方式进行排序
  5. # res = sorted(arr,reverse=True) # [20, 10, 7, 3, 1, -9]
  6. # 使用abs这个函数(求绝对值)作为sorted的key关键字参数使用
  7. res = sorted(arr,key=abs)
  8. # print(res)
  9. # 使用自定义函数
  10. # def func(num):
  11. # print(num,num % 2)
  12. # return num % 2
  13. #
  14. # arr = [3,2,4,6,5,7,9]
  15. #
  16. # # 在sorted函数中使用自定义函数对数据进行处理
  17. # res = sorted(arr,key=func)
  18. # print(res)
  19. ## 优化版
  20. arr = [3,2,4,6,5,7,9]
  21. res = sorted(arr,key=lambda x:x%2)
  22. print(res)

map(func, *iterables)

对传入的可迭代数据中的每个元素进行处理,返回一个新的迭代器

  1. map(func, *iterables)
  2. 功能: 对传入的可迭代数据中的每个元素放入到函数中进行处理,返回一个新的迭代器
  3. 参数:
  4. func 函数 自定义函数|内置函数
  5. iterables:可迭代的数据
  6. 返回值:迭代器

示例:

  1. # (1)把一个字符串数字的列表转为 整型的数字列表
  2. # ['1','2','3','4'] # ==> [1,2,3,4]
  3. # 普通的处理方法
  4. # varlist = ['1','2','3','4'] # ==> [1,2,3,4]
  5. # newlist = []
  6. # for i in varlist:
  7. # newlist.append(int(i))
  8. # print(newlist)
  9. # 使用map函数进行处理
  10. # varlist = ['1','2','3','4']
  11. # res = map(int,varlist) # <map object at 0x104ea8890>
  12. # print(list(res))
  13. # (2) [1,2,3,4] ==> [1,4,9,16]
  14. # 普通方法
  15. # varlist = [1,2,3,4]
  16. # newlist = []
  17. # for i in varlist:
  18. # res = i ** 2
  19. # newlist.append(res)
  20. # print(newlist)
  21. # 使用map函数处理这个数据
  22. varlist = [1,2,3,4]
  23. # def myfunc(x):
  24. # return x ** 2
  25. # res = map(myfunc,varlist)
  26. # print(res,list(res))
  27. # 优化版
  28. # res = map(lambda x:x**2,varlist)
  29. # print(res,list(res))
  30. # 练习作业
  31. # (3) ['a','b','c','d'] ==> [65,66,67,68]

reduce(func,iterable)

  1. reduce(func,iterable)
  2. 功能:
  3. 每一次从 iterable 拿出两个元素,放入到func函数中进行处理,得出一个计算结果,
  4. 然后把这个计算结果和iterable中的第三个元素,放入到func函数中继续运算,
  5. 得出的结果和之后的第四个元素,加入到func函数中进行处理,以此类推,直到最后的元素都参与了运算
  6. 参数:
  7. func 内置函数或自定义函数
  8. iterable 可迭代的数据
  9. 返回值:最终的运算处理结果
  10. 注意: 使用 reduce函数时,需要导入 from functools import reduce

示例:

  1. from functools import reduce
  2. ### (1) [5,2,1,1] ==> 5211
  3. # 普通方法
  4. # varlist = [5,2,1,1]
  5. # res = ''
  6. # for i in varlist:
  7. # res += str(i)
  8. # res = int(res)
  9. # print(res,type(res))
  10. '''
  11. 5 2 1 1
  12. 5 * 10 + 2 == 52
  13. 52 * 10 + 1 == 521
  14. 521 * 10 + 1 == 5211
  15. '''
  16. # 使用 reduce完成
  17. # def myfunc(x,y):
  18. # return x*10+y
  19. # varlist = [5,2,1,1]
  20. # # 调用函数
  21. # res = reduce(myfunc,varlist)
  22. # print(res,type(res))
  23. # (2) 把字符串的 '456' ==> 456
  24. # 要求不能使用int方法进行类型的转换时,如何解决上面的问题
  25. # 定义函数,给定一个字符串的数字,返回一个整型的数字
  26. def myfunc(s):
  27. vardict = {'0':0,'1':1,'2':2,'3':3,'4':4,'5':5,'6':6,'7':7,'8':8,'9':9}
  28. return vardict[s]
  29. # 1.先使用 map函数,把数字字符串,转为整型的数字
  30. iter1 = map(myfunc,'456')
  31. # 2. 把数字列表中的值,使用lambda进行二次处理
  32. iter2 = reduce(lambda x,y:x*10+y,iter1)
  33. print(iter2)

filter(func,iterable)

  1. filter(func,iterable)
  2. 功能: 过滤数据,把 iterable 中的每个元素拿到 func 函数中进行处理,
  3. 如果函数返回True则保留这个数据,返回False则丢弃这个数据
  4. 参数:
  5. func 自定义函数
  6. itereble 可迭代的数据
  7. 返回值:保留下来的数据组成的 迭代器

示例:

  1. # 要求 保留所有的偶数,丢弃所有的奇数
  2. varlist = [1,2,3,4,5,6,7,8,9]
  3. # 普通方法实现
  4. # newlist = []
  5. # for i in varlist:
  6. # if i % 2 == 0:
  7. # newlist.append(i)
  8. # print(newlist)
  9. # 使用 filter 进行处理
  10. # 定义一个函数,判断当前这个函数是否为偶数,偶数返回True,奇数返回False
  11. # def myfunc(n):
  12. # if n % 2 == 0:
  13. # return True
  14. # else:
  15. # return False
  16. #
  17. # # 调用 过滤器 函数进行处理
  18. # it = filter(myfunc,varlist)
  19. # print(it,list(it))
  20. # 优化版
  21. it = filter(lambda n:True if n % 2 == 0 else False,varlist)
  22. print(it,list(it))