我的Python成长之路---第三天---Python基础(13)---2016年1月16日(雾霾)

五、Python的常用的内置函数

  Python为我们准备了大量的内置函数,如下图所示

  这里我们只讨论红框内的内置函数

  abs(x)

  返回一个数的绝对值(模),参数可以是真说或浮点数

>>> abs(-10)
10

  all(iterable)

  如果可迭代对象(列表、元祖等)中所有的元素都是True,则返回True,否则返回False。相当于and

>>> all([1, True, 1 == 1])
True

  any(iterable)

  如果可迭代对象中任意一个元素是True,则返回True,相当于or

>>> any([None, "", [], (), {}, 0, False])
False
>>> any([None, "", [], (), {}, 0, True])
True

  说明:可以看出,通常情况下“空”(None,空字符串、空列表,0等等)都是表示False

  bin(x)

  返回一个整数的二进制字符串

>>> bin(10)
‘0b1010‘

  说明:Python使用0b开头表示这是一个二进制表达式

  class bool([x])

  返回或者新建一个布尔值对象,如果不传递参数默认返回False

>>> bool()
False
>>> bool(10)
True

  chr(i)

  返回一个整数所对应的Unicode编码所对应的字符

>>> chr(89999)
‘\U00015f8f‘
>>> chr(97)
‘a‘

  class dict(**kwarg)
  class dict(mapping, **kwarg)
  class dict(iterable, **kwarg)

  创建一个字典对象,以通过关键字参数,mapping对象,字典对象等参数方式创建

>>> dict()
{}
>>> dict(k1 = ‘v1‘, k2 = ‘v2‘)
{‘k1‘: ‘v1‘, ‘k2‘: ‘v2‘}
>>> dict(([‘k1‘, ‘v1‘], [‘k2‘, ‘v2‘]))
{‘k1‘: ‘v1‘, ‘k2‘: ‘v2‘}
>>> dict({‘k1‘:‘v1‘, ‘k2‘:‘v2‘})
{‘k1‘: ‘v1‘, ‘k2‘: ‘v2‘}

  dir([object])

  返回当前域或指定模块、对象中的所有变量名和方法名

>>> dir()
[‘__builtins__‘, ‘__doc__‘, ‘__loader__‘, ‘__name__‘, ‘__package__‘, ‘__spec__‘]
>>> dir("")
[‘__add__‘, ‘__class__‘, ‘__contains__‘, ‘__delattr__‘, ‘__dir__‘, ‘__doc__‘, ‘__eq__‘, ‘__format__‘, ‘__ge__‘, ‘__getattribute__‘, ‘__getitem__‘, ‘__getnewargs__‘, ‘__gt__‘, ‘__hash__‘, ‘__init__‘, ‘__iter__‘, ‘__le__‘, ‘__len__‘, ‘__lt__‘, ‘__mod__‘, ‘__mul__‘, ‘__ne__‘, ‘__new__‘, ‘__reduce__‘, ‘__reduce_ex__‘, ‘__repr__‘, ‘__rmod__‘, ‘__rmul__‘, ‘__setattr__‘, ‘__sizeof__‘, ‘__str__‘, ‘__subclasshook__‘, ‘capitalize‘, ‘casefold‘, ‘center‘, ‘count‘, ‘encode‘, ‘endswith‘, ‘expandtabs‘, ‘find‘, ‘format‘, ‘format_map‘, ‘index‘, ‘isalnum‘, ‘isalpha‘, ‘isdecimal‘, ‘isdigit‘, ‘isidentifier‘, ‘islower‘, ‘isnumeric‘, ‘isprintable‘, ‘isspace‘, ‘istitle‘, ‘isupper‘, ‘join‘, ‘ljust‘, ‘lower‘, ‘lstrip‘, ‘maketrans‘, ‘partition‘, ‘replace‘, ‘rfind‘, ‘rindex‘, ‘rjust‘, ‘rpartition‘, ‘rsplit‘, ‘rstrip‘, ‘split‘, ‘splitlines‘, ‘startswith‘, ‘strip‘, ‘swapcase‘, ‘title‘, ‘translate‘, ‘upper‘, ‘zfill‘]

  divmod(a, b)

  返回两个数的得商和余数组成的元祖,相当于(a // b, a % b)

>>> divmod(10, 3)
(3, 1)

  enumerate(iterable, start=0)

  返回一个迭代器,每次迭代返回一个元祖包括一个计数器,和对iterable迭代取得的值,iterable可迭代对象,包括列表、元祖等。start表示计数器的开始值,默认是0

1 enu = enumerate([‘abc‘, ‘def‘, ‘ghi‘])
2 print(enu)
3 for i in enu:
4     print(i)

  执行结果

<enumerate object at 0x0000000BE2D53510> # 可以看到返回的是一个enumerate对象
(0, ‘abc‘)
(1, ‘def‘)
(2, ‘ghi‘)

  注意:返回的是是一个迭代器,迭代完了空了,如果需要重复使用,最好转化为一个列表对象保存到变量中,并且计数器是从0开始计数的

>>> li = list(enumerate([‘abc‘, ‘def‘, ‘ghi‘]))
>>> li
[(0, ‘abc‘), (1, ‘def‘), (2, ‘ghi‘)]

  可以指定start的开始值

>>> li = list(enumerate([‘abc‘, ‘def‘, ‘ghi‘], 2))
>>> li
[(2, ‘abc‘), (3, ‘def‘), (4, ‘ghi‘)]

  eval(expression, globals=None, locals=None)

  将的字符串形式的算数表达式进行计算,并返回结果

>>> eval(‘3 + 4 * (1 - 3)‘)
-5

  filter(function, iterable)

  接收一个函数和一个可迭代对象,将可迭代对象的每一个元素都作为参数执行函数,函数返回为真的放到一个新的可迭代对象中,并将新的可迭代对象返回

1 def is_dual(num):
2     if num % 2 == 0:
3         return True
4     else:
5         return False
6
7 nums = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19]
8
9 print(list(filter(is_dual, nums))) # 由于返回的是filter对象,所以要转化为list列表对象进行查看

  执行结果

[2, 4, 6, 8, 10, 12, 14, 16, 18]

  class float([x])

  创建一个浮点类型的对象

>>> float(‘0.5‘)
0.5
>>> float(0.5)
0.5

  help([object])

  返回某个对象的帮助信息

  hex(x)

  返回一个整数的16进制表达式

>>> hex(23)
‘0x17‘

  说明:hex函数只接受整数类型的参数

  id(object)

  返回对象的id(可以理解为Python为每个对象的编号,或者理解为是Python对象内存地址的表达形式)

>>> id(1)
10455040
>>> id(2)
10455072

  input([prompt])

  接受用户从控制台的输入,并将用户输入的信息,以字符串的返回,prompt表示输入时前显示的字符串

>>> s = input(‘python>>‘)
python>>123
>>> s
‘123‘

  class int(x=0)
  class int(x, base=10)

  创建一个整数类型的对象,默认如果创建的0,如果传递的是字符串类型的,可以把字符串表达式所表示的整数转化为整数类型,base表示的传递的字符串进制,默认是十进制

>>> int()
0
>>> int(‘1‘)
1
>>> int(‘1010‘, base = 2)
10

  len(s)

  返回一个对象的长度(或者元素的个数)

>>> len(‘abc‘)
3
>>> len([1, 2])
2

  说明:所谓的长度一般只字符串,像整数、浮点数等数据类型没有len方法,会报如下错误

>>> len(10)
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
TypeError: object of type ‘int‘ has no len()

  class list([iterable])

  将一个可迭代对象转化为列表

>>> list([1, 2, 3])
[1, 2, 3]
>>> list((1, 2, 3))
[1, 2, 3]
>>> list({‘k1‘:‘v1‘, ‘k2‘:‘v2‘})
[‘k2‘, ‘k1‘]

  说明:可以看到字典只是把key组成了列表,因为字典真正迭代的是key,value只是与key对应而已

  map(function, iterable, ...)

  接收一个函数和一个可迭代对象,将可迭代对象里的每一个元素都做作为参数传递到函数中,并把函数的返回结果保存到一个map对象中

>>> map(lambda x: x**2, [1, 2, 3])
<map object at 0x7f0700026518>
>>> list(map(lambda x: x**2, [1, 2, 3]))
[1, 4, 9]

  说明:函数可以是匿名函数,另外函数必须有返回值,如果没有返回值,虽然不会报错,但没有任何意义,例如

>>> def f(x):
...     x*2
...
>>> list(map(f, [1, 2, 3]))
[None, None, None]

  max(iterable, *[, key, default])

  max(arg1, arg2, *args[, key])

  返回可迭代对象中(或者2个以上参数中)最大的值

>>> max(1, 2, 3)
3
>>> max([1, 2, 3])
3

  min(iterable, *[, key, default])

  min(arg1, arg2, *args[, key])

  返回可迭代对象中(或者2个以上参数中)最大的值

>>> min(1, 2, 3)
1
>>> min([1, 2, 3])
1

  oct(x)

  将一个数转化为8进制的表达形式

>>> oct(9)
‘0o11‘

  说明:Python中0o表示8进制

  open(file, mode=‘r‘, buffering=-1, encoding=None, errors=None, newline=None, closefd=True, opener=None)

  打开文件并返回文件文件对象,file表示文件名(可以是绝对路径,也可以是相对路径),mode表示打开方式,默认的是rt模式,表示只读的文本格式

  ord(c)

  返回一个字符的Unicode编码

>>> ord(‘a‘)
97
>>> ord(‘中‘)
20013

  pow(x,y[,z])

  如果只传递两个参数x和y,就计算x的y次方,相当于x ** y

  参数z表示将x ** y的结果对z取模,相当于x ** y % z

>>> pow(2, 3)
8
>>> pow(2, 3, 3)
2

  print(*objects, sep=‘ ‘, end=‘\n‘, file=sys.stdout, flush=False)

  打印函数,object表示要输出的对象,sep表示多个对象之间的分隔符,默认是空格,end表示末尾的字符,默认是回车符,file表示输出的文件,默认为sys.stdout也就是终端(标准输出)

>>> print(‘abc‘)
abc
>>> print(‘abc‘,‘def‘, sep = ‘*‘)
abc*def
>>> print(‘abc‘,‘def‘, sep = ‘*‘, end = ‘end‘)
abc*defend
>>> f = open(‘print.log‘, ‘w‘)
>>> print(‘abc‘,‘def‘, sep = ‘*‘, end = ‘end‘, file = f)
>>> f = open(‘print.log‘, ‘r‘)
>>> f.read()
‘abc*defend‘

  range(stop)

  range(start, stop[, step])

  生成大于等于start,小于stop步长为step的数字序列,start默认是0

>>> list(range(1, 10))
[1, 2, 3, 4, 5, 6, 7, 8, 9]
>>> list(range(1, 10, 2))
[1, 3, 5, 7, 9]
>>> list(range(5))
[0, 1, 2, 3, 4]

  reversed(seq)

  翻转一个序列,序列对象必须是有序的,也就是对象必须包含__reversed__()方法

>>> reversed([0, 1, 2, 3, 4])
<list_reverseiterator object at 0x7fcc954acd68>
>>> list(reversed([0, 1, 2, 3, 4]))
[4, 3, 2, 1, 0]

  round(number[, ndigits])

  返回一个浮点数的后面保留ndigits位小数的结果,四舍五入,小数点位数不足,不补0

>>> round(1.236, 2)
1.24
>>> round(1.2, 2)
1.2

  class set([iterable])

  根据序列对象创建集合对象

>>> set([1, 2, 4, 2])
{1, 2, 4}

  sorted(iterable[, key][, reverse])

  对一个序列对象进行排序,key接收一个函数,将序列的每一个函数处理返回的结果作为排序的依据,比如字符串都转换成小写排序或字典按照key或value排序等,reverse表示对排序的结果是否排序,默认字符串是先大写后小写的顺序排序的

>>> sorted([‘A‘, ‘b‘, ‘c‘])
[‘A‘, ‘b‘, ‘c‘]
>>> sorted([‘A‘, ‘b‘, ‘C‘])
[‘A‘, ‘C‘, ‘b‘]
>>> sorted([‘A‘, ‘b‘, ‘C‘], key = lambda x: x.lower())
[‘A‘, ‘b‘, ‘C‘]
>>> sorted([‘A‘, ‘b‘, ‘C‘], key = lambda x: x.lower(), reverse = True)
[‘C‘, ‘b‘, ‘A‘]

  class str(object=‘‘)

  创建一个字符串对象,或者将一个对象转化为字符串对象

>>> str(‘abc‘)
‘abc‘
>>> str(1234)
‘1234‘

  sum(iterable[, start])

  返回一个序列对象的相加的总和在加上start,start默认是0,序列对象要么全是数字要么都是字符串,字符串就相当于把它们都拼接在一起

>>> sum([1, 2, 4])
7
>>> sum([1, 2, 4], 1)
8

  疑惑:说是可以使用字符串,但是报错

>>> sum([‘ab‘, ‘bc‘, ‘cd‘])
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
TypeError: unsupported operand type(s) for +: ‘int‘ and ‘str‘

  tuple([iterable])

  创建一个元祖对象,或将一个对象转化为元祖

>>> tuple()
()
>>> tuple([1, 2, 4])
(1, 2, 4)

  class type(object)

  class type(name, bases, dict)

  返回一个对象的类型

>>> type(1)
<class ‘int‘>
>>> type(str)
<class ‘type‘>

  vars([object])

  返回模块,类,实例或者任何其他有__dict__属性的对象的__dict__属性,默认是显示当前环境的

>>> vars()
{‘f‘: <_io.TextIOWrapper name=‘print.log‘ mode=‘r‘ encoding=‘UTF-8‘>, ‘__spec__‘: None, ‘__builtins__‘: <module ‘builtins‘ (built-in)>, ‘__name__‘: ‘__main__‘, ‘__doc__‘: None, ‘__package__‘: None, ‘__warningregistry__‘: {("unclosed file <_io.TextIOWrapper name=‘print.log‘ mode=‘w‘ encoding=‘UTF-8‘>", <class ‘ResourceWarning‘>, 1): True}, ‘__loader__‘: <class ‘_frozen_importlib.BuiltinImporter‘>}
>>> import sys
>>> vars(sys)
{‘version_info‘: sys.version_info(major=3, minor=4, micro=0, releaselevel=‘final‘, serial=0), ‘getswitchinterval‘: <built-in function getswitchinterval>, ‘__name__‘: ‘sys‘, ‘path_hooks‘: [<class ‘zipimport.zipimporter‘>, <function FileFinder.path_hook.<locals>.path_hook_for_FileFinder at 0x7fcc97b51ae8>],后面省略n多行

  zip(*iterables)

  将多个元素组成一个新的zip对象,zip对象的元素个数取决于元素最少的参数

>>> x = [1, 2, 3, 4]
>>> y = [‘a‘, ‘b‘, ‘c‘]
>>> zip(x, y)
<zip object at 0x7fcc954aea08>
>>> list(zip(x, y))
[(1, ‘a‘), (2, ‘b‘), (3, ‘c‘)]
时间: 2024-10-05 21:47:00

我的Python成长之路---第三天---Python基础(13)---2016年1月16日(雾霾)的相关文章

我的Python成长之路---第三天---Python基础(12)---2016年1月16日(雾霾)

四.函数 日常生活中,要完成一件复杂的功能,我们总是习惯把“大功能”分解为多个“小功能”以实现.在编程的世界里,“功能”可称呼为“函数”,因此“函数”其实就是一段实现了某种功能的代码,并且可以供其它代码调用. 假设我们在编程过程中需要计算圆形的面积.如果我们不是用函数,每次需要计算原型面积的时候都需要这样 1 r1 = 12.34 2 r2 = 9.08 3 r3 = 73.1 4 s1 = 3.14 * r1 * r1 5 s2 = 3.14 * r2 * r2 6 s3 = 3.14 * r

我的Python成长之路---第三天---Python基础(9)---2016年1月16日(雾霾)

一.集合 set和dict类似,也是一组key的集合,但不存储value.由于key不能重复,所以,在set中,没有重复的key. 集合和我们数学中集合的概念是一样的,也有交集,并集,差集,对称差集等概念 1.集合的定义 定义一个集合需要提供一个列表作为参数,也可以不传入参数创建一个空的集合 >>> s = set([1, 2, 2, 3]) >>> s {1, 2, 3} # 可以看到在创建集合对象对过程中已经为我们把重复的元素剔除掉了 >>> s

python成长之路第三篇(1)_初识函数

目录: 函数 1.为什么要使用函数 2.什么是函数 3.函数的返回值 4.文档化函数 5.函数传参数 文件操作(二) 1.文件操作的步骤 2.文件的内置方法 函数: 一.为什么要使用函数 在日常写代码中,我们会发现有很多代码是重复利用的,这样会使我们的代码变得异常臃肿,比如说: 我们要写一个验证码的功能 例子: 比如说我们要进行一些操作,而这些操作需要填写验证码 验证码代码:  1 import random   2 number_check = ''   3 for i in range(0,

python成长之路第三篇(4)_作用域,递归,模块,内置模块(os,ConfigParser,hashlib),with文件操作

打个广告欢迎加入linux,python资源分享群群号:478616847 目录: 1.作用域 2.递归 3.模块介绍 4.内置模块-OS 5.内置模块-ConfigParser 6.内置模块-hashlib 7.with文件操作 代码执行环境默认为3.5.1 一.作用域 (1)什么是作用域,官方来说作用域就是就是有不同的命名空间,就像下面的代码一样,a=1它的作用域是全局的,也在全局的命名空间当中,当函数 action中的a=2它就在局部的作用域中,也在局部的命名空间当中. a = 1def

Python成长之路 第一篇 《Python基础》

1.python文件命名 - 后缀名可以是任意的,但为规范便于识别,后缀名应为 .py 2.两种执行方式    python解释器   py文件路径     python   进入解释器: 实时输入并获取到执行结果 3.解释器路径 在Linux系统中应添加  #!/user/bin/env python    , windows系统中可不添加 4.编码 # -*- coding:utf8 -*-  (在python3中可不加,python只要出现中文头部必须加) ascill  只能编译英文 u

python成长之路第三篇(2)_正则表达式

打个广告欢迎加入linux,python资源分享群群号:478616847 目录: 1.什么是正则表达式,python中得正则简介 2.re模块的内容 3.小练习 一.什么是正则表达式(re) 正则表达式相信很多人都熟悉了,在python中正则表达式的支持是通过re(regular expression)模块,正则表达式是可以匹配文本片段的模式,简单的是正则表达式就是普通的字符串,可以处理字符串.也就是说正则表达式的存在就是来处理文本字符串的 下面来熟悉下正则中的几个概念: 1.通配符 通配符是

Python高手之路【三】python基础之函数

基本数据类型补充: set 是一个无序且不重复的元素集合 1 class set(object): 2 """ 3 set() -> new empty set object 4 set(iterable) -> new set object 5 6 Build an unordered collection of unique elements. 7 """ 8 def add(self, *args, **kwargs): # r

我的Python成长之路---第四天---Python基础(16)---2016年1月24日(寒风刺骨)

四.正则表达式 字符串是编程时涉及到的最多的一种数据结构,对字符串进行操作的需求几乎无处不在.比如判断一个字符串是否是合法的Email地址,虽然可以编程提取@前后的子串,再分别判断是否是单词和域名,但这样做不但麻烦,而且代码难以复用. 正则表达式是一种用来匹配字符串的强有力的武器.它的设计思想是用一种描述性的语言来给字符串定义一个规则,凡是符合规则的字符串,我们就认为它"匹配"了,否则,该字符串就是不合法的. 下面这张图展示了使用正则表达式匹配的流程 1.Python支持的正则表达式元

Python学习之路(三):基础知识之运算符

1.while循环 1.1 while基本格式 while循环体格式为: while 循环条件: 循环体1 循环体2 1 count = 1 2 while count <= 10: # 循环条件的关键在于控制循环次数 3 if count != 7: 4 print(count) 5 count = count + 1 1.2 break 运用break能够在适当的条件下终止循环,即跳出当前循环,执行循环外下面的语句. 1 num = 1 2 while num < 3: 3 print(n