1.  

python内置函数

  截止到python版本3.6.2,python一共为我们提供了68个内置函数。它们就是python提供给你直接可以拿来使用的所有函数

    Built-in Functions    
abs() dict() help() min() setattr()
all() dir() hex() next() slice()
any() divmod() 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()  

思维导图:https://www.processon.com/mindmap/5a97b9d7e4b083b043a1dcd5

以下是具体分布:

python所用内置函数:

https://docs.python.org/3/library/functions.html

http://www.cnblogs.com/sesshoumaru/category/894935.html

以下需常看的内容:

  1. 算法相关
  2.  
  3. # divmod() 这个做项目后期会用到
  4. print(divmod(10, 3)) # 取商/余
  5. ---(3, 1)
  6.  
  7. # round()
  8. print(round(3.1415926, 2)) # 求取精确度,保留两位小数
  9. ---3.14
  10.  
  11. # power()
  12. print(pow(2, 3)), print(2**3) # 求幂运算,两个等同
  13. ---8
  14.  
  15. # complex:函数用于创建一个值为real + imag*j的复数或者转化一个字符串或数为复数。
  16. 如果第一个参数为字符串,则不需要指定第二个参数。
  17. complex(1,4)
  18. ---(1+4j)
  19. complex(1) # 数字
  20. ---(1 + 0j)
  21. complex("1") # 当做字符串处理
  22. ---(1 + 0j)
  23.  
  24. # abs(): 如果输入是整数或者浮点数,它返回的是输入值的绝对值;
  25. 如果输入是复数(complex number),那么返回这个复数的模
  26.  
  27. # reversed() 顺序的反转
  28. l = [1, 2, 3, 4]
  29. print(list(reversed(l))) # 是生成了一个新的列表,没有改变原来的列表
  30. ---[4,3,2,1]
  31. l.reverse() # 在现在的列表的基础上修改了,修改的是原来的列表
  32. print(l)
  33. ---[4,3,2,1]
  34. --------------------------------------------------------------------------------------------
  35. 内存相关
  36.  
  37. # hash:获取可哈希对象(int,str,Bool,tuple)的的哈希值
  38. (如果在Python中需要对用户输入的密码或者其他内容进行加密,出于安全性考虑首选的方法是生成hash值)
  39. print(hash('arg'))
  40. -8969565126408161272 # 这里虽然一次运行时值是一致的,但是重新运行时得到的值就不相同了,详见知乎
  41. print(hash(True)) # 1
  42. print(hash(False)) # 0
  43.  
  44. # id:返回对象的唯一标识符,用整数表示。在程序生命周期内,这个标识符常量是唯一的。
  45. id(2)
  46. ---1940280128
  47. --------------------------------------------------------------------------------------------
  48. 进制转换相关
  49.  
  50. # bin:将十进制转换成二进制并返回
  51. # oct:将十进制转化成八进制字符串并返回
  52. # hex:将十进制转化成十六进制字符串并返回
  53. print(bin(5), type(bin(5)))
  54. ---0b101 <class 'str'>
  55. print(oct(5), type(oct(5)))
  56. ---0o5 <class 'str'>
  57. print(hex(5), type(hex(5)))
  58. ---0x5 <class 'str'>
  59. ---------------------------------------------------------------------------------------------
  60. 字符串相关
  61. # repr:返回一个对象的string形式(原形毕露,连引号都给打印出来了)
  62. print(repr('{"name":"alex"}'))
  63. ---'{"name":"alex"}'
  64. print('{"name":"alex"}')
  65. ---{"name":"alex"}
  66. (这里其实就和格式化字符串概念一样)
  67. %r ---是什么就返回什么
  68. %d ---返回整形数字
  69. %f ---返回浮点型数字
  70. %s ---返回字符串类型
  71.  
  72. # format:与具体数据相关,用于计算各种小数,精算等,此外这个用于格式化输出很重要(详见我的博客第二节)
  73. # 字符串可以提供的参数,指定对齐方式,<是左对齐, >是右对齐,^是居中对齐
  74. print(format('test', '<20'))
  75. print(format('test', '>20'))
  76. print(format('test', '^20'))
  77. 其他用法详见链接:http://www.cnblogs.com/jin-xin/articles/8423937.html
  78.  
  79. # bytes:用于不同编码之间的转换,只能编码,将unicode ---> 非unicode bytes(s1,encoding='utf-8')。
  80. print('你好'.encode('utf-8'))
  81. ---b'\xe4\xbd\xa0\xe5\xa5\xbd'
  82. bs = bytes('你好', encoding='utf-8')
  83. print(bs)
  84. ---b'\xe4\xbd\xa0\xe5\xa5\xbd'
  85. (两个结果是一样的,但是明显没有直接encode好用)
  86.  
  87. # ord:输入字符找该字符编码的位置 unicode
  88. # chr:输入位置数字找出其对应的字符 unicode
  89. # ascii:是ascii码中的返回该值,不是就返回\u...
  90. print(ord('a'))
  91. ---97
  92. print(ord('中'))
  93. ---20013
  94. print(chr(97))
  95. ---a
  96. print(chr(20013))
  97. ---中
  98. print(ascii('a'))
  99. ---'a'
  100. print(ascii('中'))
  101. ---'\u4e2d'
  102.  
  103. # bytearry:返回一个新字节数组。这个数组里的元素是可变的,并且每个元素的值范围: 0 <= x < 256
  104. ret = bytearray('alex', encoding='utf-8')
  105. print(id(ret))
  106. ---2448694454456
  107. print(ret)
  108. ---bytearray(b'alex')
  109. print(ret[0]) # 找到字母a对应ascll表的位置
  110. ---97
  111. ret[0] = 65 # 将其通过修改ascll表的位置对其字母进行修改
  112. print(ret)
  113. ---bytearray(b'Alex')
  114. print(id(ret))
  115. 2448694454456 # 对其修改完但是它的id并没有发生改变
  116.  
  117. # memoryview:
  118. ret = memoryview(bytes('你好',encoding='utf-8'))
  119. print(len(ret))
  120. ---6
  121. print(ret) # 打印出内存地址
  122. ---<memory at 0x0000021B7F2BB1C8>
  123. print(bytes(ret[:3]).decode('utf-8')) #通过内存地址切片
  124. ---你
  125. print(bytes(ret[3:]).decode('utf-8'))
  126. ---好
  127. ---------------------------------------------------------------------------------------------
  128. 字符串代码执行相关
  129.  
  130. # eval函数() # 执行字符串类型的代码,并返回最终结果
  131. print(eval('3+5'))
  132. ---8
  133. num = eval('6+8+5')
  134. print(num)  # 执行了有返回值
  135. ---19
  136.  
  137. # exec()函数  # 执行字符串类型的代码,它属于流程语句
  138. num = exec('6+8+5')
  139. print(num) # 执行但是没有返回值
  140. ---None
  141.  
  142. ret1 = '''
  143. li = [1,2,3]
  144. for i in li:
  145. print(i)
  146. '''
  147. print(exec(retl))
  148. ---1
  149. ---2
  150. ---3
  151. ---None
  152.  
  153. # compile # 将字符串类型的代码翻译,代码对象能够通过exec()语句执行或者是eval()进行求值
  154. '''
  155. 参数说明:   
  156.  
  157. 1. 参数source:字符串或者动态执行的代码段。  
  158.  
  159. 2. 参数filename:代码文件名称,如果不是从文件读取代码则传递一些可辨认的值。
  160. 当传入了source参数时,filename参数传入空字符即可。  
  161.  
  162. 3. 参数model:指定编译代码的种类,可以指定为 ‘exec’,’eval’,’single’
  163. 当source中包含流程语句时,model应指定为‘exec’;
  164. 当source中只包含一个简单的求值表达式,model应指定为‘eval’;
  165. 当source中包含了交互式命令语句,model应指定为'single'。
  166. '''
  167.  
  168. # 流程语句使用exec
  169. code1 = 'for i in range(0,3): print (i)'
  170. compile1 = compile(code1, '', 'exec')
  171. exec(compile1)
  172. ---0
  173. ---1
  174. ---2
  175.  
  176. # 简单求值表达式用eval
  177. code2 = '1 + 2 + 3 + 4'
  178. compile2 = compile(code2, '', 'eval')
  179. print(eval(compile2))
  180. ---10
  181.  
  182. # 交互语句用single  # 略,看不懂,也用不上
  183. -------------------------------------------------------------------------------------------
  184. 其他容易遗忘的知识点
  185.  
  186. # help():用于查看函数或模块用途的详细说明
  187.  
  188. # dir():函数不带参数时,返回当前范围内的变量、方法和定义的类型列表;
  189. 带参数时,返回参数的属性、方法列表。
  190.  
  191. # callable:函数用于检查一个对象是否是可调用的。如果返回True,object仍然可能调用失败;但如果返回False,调用对象ojbect绝对不会成功。
  192. def func1():
  193. print(555)
  194. a = 3
  195. f = func1
  196. print(callable(f))
  197. ---True
  198. print(callable(a))
  199. ---False
zip函数
 zip()是Python的一个内建函数,它接受一系列可迭代的对象作为参数,将对象中对应的元素打包成一个个tuple(元组),
  然后返回由这些tuples组成的list(列表)。若传入参数的长度不等,则返回list的长度和参数中长度最短的对象相同。
  利用*号操作符,可以将list unzip(解压)。
  py3中zip()是可迭代对象,使用时必须将其包含在一个list中,方便一次性显示出所有结果
   →这里和py2的差别很大啊
  1. a = [1,2,3]
  2. b = [4,5,6]
  3. c = [4,5,6,7,8]
  4. d = zip(a,b)
    printlist(d))
  5. ---[(1, 4), (2, 5), (3, 6)]
  1. d = dict(zip(a,b)) # 通过使用zip函数来构造字典
    print(d)
    ---{1: 4, 2: 5, 3: 6}
  1. d = {} # 也是字典类型
    for k,v in zip(a,b) : d[k] = v
    print(d)
    ---{1: 4, 2: 5, 3: 6}
  1. l = ['a', 'b', 'c', 'd', 'e','f']
    a = list(zip(l[:-1], l[1:])) # l[:-1]后面'f'没取,l[1:]前面'a'没取
    print(a)
    ---[('a', 'b'), ('b', 'c'), ('c', 'd'), ('d', 'e'), ('e', 'f')]

二维矩阵变换:

  1. a = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]
  2. b = [[row[col] for row in a] for col in range(len(a[0]))]
  3. print(b)
  4. ---[[1, 4, 7], [2, 5, 8], [3, 6, 9]]
  5.  
  6. a = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]
    c = list(zip(*a))
    print(c)
    ---[(1, 4, 7), (2, 5, 8), (3, 6, 9)]
  1.  
  1. d = map(list,zip(*a))
    print(list(d))
    ---[[1, 4, 7], [2, 5, 8], [3, 6, 9]]

其它内置函数(zip等)的更多相关文章

  1. python3 之 内置函数Zip

    python3 内置函数zip 一.简介: 该函数用于将多个可迭代对象作为参数,依次将对象中对应的元素打包成一个个元组,然后返回由这些元组组成的对象.二.实例1: name = ['张三','李四', ...

  2. python 内置函数zip,map,三元,lambda表达式

    #内置函数zip(),将多个可迭代对象(集合等)按照顺序进行组合成tuple元祖,放在zip 对象进行存储,: #当参数为空时候,返回空 #如果 zip() 函数压缩的两个列表长度不相等,那么 zip ...

  3. Python 内置函数 -- zip(), sorted(), filter()和map()

    内置函数1. zip() 打包(木桶效应)描述: zip() 函数用于将可迭代的对象作为参数, 将对象中对应的元素打包成一个个元组, 然后返回由这些元组组成的列表语法: zip([iterable, ...

  4. 内置函数zip,map,even

    内置函数的补充:1.zip:l1 = ['a','b','c','e','f','g']l2 = [1,2,3]l3=['A','B','C']L4=['牛','牛','niu']#zip,就是把俩l ...

  5. python内置函数zip

    zip() 函数用于将可迭代的对象作为参数,将对象中对应的元素打包成一个个元组,然后返回由这些元组组成的列表. 如果各个迭代器的元素个数不一致,则返回列表长度与最短的对象相同,利用 * 号操作符,可以 ...

  6. 内置函数zip()

    zip有拉链的意思,zip函数像拉链一样将0个或多个可迭代对象按相同位置组合成一个zip对象,该zip对象的每个元素是由每个可迭代对象的相同位置的元素组成的元祖. 如果zip中有多个序列,而各序列的长 ...

  7. Python学习笔记014——迭代工具函数 内置函数zip()

    1 描述 zip() 函数用于将可迭代的对象作为参数,将对象中对应的元素打包成一个个元组,然后返回由这些元组组成的列表. 如果各个迭代器的元素个数不一致,则返回列表长度与最短的对象相同,利用 * 号操 ...

  8. python学习笔记(十六)内置函数zip、map、filter的使用

    1.zip,就是把两个或者多个list,合并到一起,如果想同时循环2个list的时候,就使用zip.示例如下: l1 = ['a','b','c','e','f','g'] l2 = [,,] l3= ...

  9. Python:内置函数zip()

    zip函数接受任意多个可迭代对象作为参数,将对象中对应的元素打包成一个tuple,然后返回一个可迭代的zip对象. 这个可迭代对象可以使用循环的方式列出其元素 若多个可迭代对象的长度不一致,则所返回的 ...

随机推荐

  1. python函数基础学习

    函数的定义与调用: def 函数名(参数1,参数2): ‘’’函数注释’’’ print(‘函数体’) return 返回值 定  义:def关键字开关,空格之后接函数名和圆括号,最后冒号结尾 def ...

  2. Cookie和Session入门(一)

    目录一)背景介绍二)Cookie机制三)Session机制四)两者比较五)参考资料链接一)背景介绍Cookie与Session是常用的会话跟踪技术.1.Cookie通过在客户端记录信息确定用户身份,S ...

  3. sysbench测试MySQL筛选tps

    log=$1tps_array=`awk -F '[,:]' '{print $4}' ${log}`zero=0 for tps in ${tps_array}do tps=`echo ${tps} ...

  4. 性能测试工具LoadRunner04-LR之浏览器打不开

    环境:win7+lr11 IE浏览器要在9以下,9以上lr11是调不起来的 火狐浏览器,我用的是28,最新版本的也调不起来 可以调起浏览器但没有事件? 1.把INTERNET高级设置中的“启用第三方浏 ...

  5. spring 基础知识复习

    spring是一个分层架构,由 7 个定义良好的模块组成.Spring 模块构建在核心容器之上,核心容器定义了创建.配置和管理 bean 的方式. 组成spring框架的每个模块(或组件)都可单独存在 ...

  6. javascript获取行间样式和非行间样式--兼容写法

    style:获取行间样式: currentStyle:获取计算后的样式,也叫当前样式.最终样式. 优点:可以获取元素的最终样式,包括浏览器的默认值,而不像style只能获取行间样式,所以更常用到.注意 ...

  7. 【密码学】RSA密钥长度、明文长度和密文长度

    本文介绍RSA加解密中必须考虑到的密钥长度.明文长度和密文长度问题,对第一次接触RSA的开发人员来说,RSA算是比较复杂的算法,天缘以后还会补充几篇RSA基础知识专题文章,用最简单最通俗的语言描述RS ...

  8. HTML--备忘点

    1.文档内的链接

  9. html和Url转码与解码

    JS (JQuery)对Html.URL的编码与解码 首先引入JQuery文件 1.js对Html编码 function htmlEncode(value){ return $('<div/&g ...

  10. 粗看ES6之JSON

    标签: es6 ES6新增JSON特性不是特别多,只是针对JSON某些情况下的写法上有一些优化: 当key值和value值对应变量名相同时 json对像中的方法书写 示例代码如下: <!DOCT ...