先上一张图,python中内置函数:

python官方解释在这:点我点我

继续聊内置函数:

callable(object):检查对象是否可被调用,或是否可执行,结果为bool值

def f1():pass
f2 = 123
print(callable(f1))
print(callable(f2))out:
True
False


char():

ord():

这两个一起讲,都是对应ASCii表的,char(obect)将十进制数字转化为ascii中对应的字母,ord(object)将字母转化为ascii中对应的十进制数字。

顺便上一张ascii表吧,以便以后查询:

用处呢,可以用来搞随机验证码等等,随机验证码在这:点我点我

>>> chr(89)
'Y'
>>> chr(64)
'@'
>>> ord('x')
120
>>> 


compile():将字符串编译成python代码,格式:compile( str, file, type )

compile语句是从type类型(包括’eval’: 配合eval使用,’single’: 配合单一语句的exec使用,’exec’: 配合多语句的exec使用)中将str里面的语句创建成代码对象

exam:

>>> s = "print(123)"
>>> r = compile(s, "<string>", "exec")
>>> exec(r)
123
>>> 


执行:

eval()  exec()

eval():格式:eval( obj[, globals=globals(), locals=locals()] ), 运算符,表达式:只能执行运算符,表达式, 并且eval() 有返回值

exec(): 格式:exec(obj),执行代码或者字符串,没有返回值,执行代码时,接收代码或者字符串

exam:

>>> s='8*8'
>>> eval(s)
64    #有返回值
>>> >>> exec('8+7*8')    #无返回
>>> eval('8+7*8')
64
>>> 


dir():快速查看对象提供了哪些功能

help():查看对象使用帮助,显示功能详情

exam:

>>> dir(list)
['__add__', '__class__', '__contains__', '__delattr__', '__delitem__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__gt__', '__hash__', '__iadd__', '__imul__', '__init__', '__iter__', '__le__', '__len__', '__lt__', '__mul__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__reversed__', '__rmul__', '__setattr__', '__setitem__', '__sizeof__', '__str__', '__subclasshook__', 'append', 'clear', 'copy', 'count', 'extend', 'index', 'insert', 'pop', 'remove', 'reverse', 'sort']
>>> help(list)
Help on class list in module builtins:class list(object)|  list() -> new empty list|  list(iterable) -> new list initialized from iterable's items|  |  Methods defined here:

View Code


divmod() :求商和余数,返回数据类型是元组,常用于页面分页计算

>>> r = divmod(100, 10)
>>> print(r[0])
10
>>> print(r[1])
0
>>> print(r)
(10, 0)#也可这么用
>>> n1,n2=divmod(100,9)
>>> print(n1,n2)
11 1
>>> 


isinstance():判断对象是否为某类的实例

>>> s='alex'
>>> isinstance(s,str)
True
>>> li=[1,2,3,4]
>>> isinstance(li,dict)
False
>>> 


filter(func,obj):过滤,其中obj为可迭代的对象, 循环第二个参数,将每一个循环元素,去执行第一个参数(函数),如果函数的返回值为True,即合法

filter()用来筛选,函数返回True,将元素添加到结果中。

需要注意的是,filter如果直接打印的话,是一个内存地址,需要将其转化为有序元素,比如list等。

exam:

def f1(args):result = []for item in args:if item > 22:result.append(item)return resultli = [11, 22, 33, 44, 55]
ret = f1(li)
print(ret)out:
[33, 44, 55]===================
li=[11,22,33,45,67,23,14,52,]
def f1(a):if a > 22:return 1
res=filter(f1,li)
print(type(res))
print(list(res))out:
<class 'filter'>
[33, 45, 67, 23, 52]
=================
li = [11, 22, 33, 44, 55]
res=filter(lambda a:a>27,li)
print(list(res))out:
[33, 44, 55]

可以看出来,使用lambda表达式可使代码更简洁,因为lambda表达式是自动return,不用像函数那样特意定义返回值


map():格式与filter相似,map(函数,可迭代的对象(可以for循环的东西))
功能: 把可迭代的对象使用函数做处理,批量操作,将函数返回值添加到结果中
exam:
li=[11,22,33,45,67,23,14,52,]
res=map(lambda a:a+100,li)
print(list(res))out:
[111, 122, 133, 145, 167, 123, 114, 152]

filter与map的区别:

filter()是使用函数对可迭代对象进行筛选,如果函数返回为True,将对象添加到结果中

map()是使用函数对可迭代对象进行处理,批量操作,将函数返回值添加到结果中


frozenset() :不可变集合,与set()相对

frozenset() 是冻结的集合,它是不可变的,存在哈希值,好处是它可以作为字典的key,也可以作为其它集合的元素。缺点是一旦创建便不能更改,没有add,remove方法

set()是可变的,有add(),remove()等方法。既然是可变的,所以它不存在哈希值


globals()     所有的全局变量
locals()     所有的局部变量 
exam:
NAME = "ALEX"def show():a = 123c = 123print(locals())print(globals())show()out:
{'c': 123, 'a': 123}
{'__package__': None, '__spec__': None, '__cached__': None, '__loader__': <_frozen_importlib_external.SourceFileLoader object at 0x1007a5c50>, 'show': <function show at 0x10137b620>, '__builtins__': <module 'builtins' (built-in)>, '__name__': '__main__', '__file__': '/Users/shane/PycharmProjects/Py_study/Base/S4/test.py', '__doc__': None, 'NAME': 'ALEX'}


hash():生成hash值,生成的值不是固定的

exam:

s = "hhhasdfasdfasdfasdfasdfasdfasdfasdfa" \"sdfasdfasdfhhhasdfasdfasdfasdfasdfasdfasdfasdfasdfasdfasdf"print(hash(s))out:
1352149349547718846


len() 计算元素的长度的,但需要注意的一点是汉字:

在2.7中,len('汉字')是按字节算的,值为6

在3.5中,len('汉字')是按字符算的,值为2

exam:

s='李杰'
print(len(s))
b=bytes(s,encoding='utf8')
print(len(b))out:
2
6


min() 求最小
max()     求最大
sum()     求和 
exam:没难度
>>> li=[1,2,56,7,8,90]
>>> min(li)
1
>>> max(li)
90
>>> sum(li)
164
>>> 


pow() 求幂,等同于**

exam:

>>> pow(10,3)
1000
>>> 10**3
1000
>>> 


reversed() 反转

exam:

li = [11,22,1,1]#与 li.reverse() 相同

reversed(li)
print(li)out:
[11, 22, 1, 1]


round() 四舍五入

exam:

>>> round(1.4)
1
>>> round(5.8)
6
>>> 


sorted()     排序

exam:

li = [11,2,1,1]
li.sort()等同:
sorted(li)


zip()  接受任意多个(包括0个和1个)序列作为参数,返回一个tuple列表,不是很好描述

exam:

l1 = ["alex", 11, 22, 33]
l2 = ["is", 11, 22, 33]
l3 = ["sb", 11, 22, 33]r = zip(l1, l2, l3)
print(r)
print(list(r))out:
<zip object at 0x10137cfc8>    #注意结果,print的话也是内存地址
[('alex', 'is', 'sb'), (11, 11, 11), (22, 22, 22), (33, 33, 33)]

注意长度计算方式:

x = [1, 2, 3]
y = [4, 5, 6, 7]
xy = zip(x, y)
print(list(xy))out:
[(1, 4), (2, 5), (3, 6)]

一个列表:

x = [1, 2, 3]
zx=zip(x)
print(list(zx))
y=[1,]
zy=zip(y)
print(list(zy))out:
[(1,), (2,), (3,)]
[(1,)]


slice()     切片

格式:slice(start,stop,step) 也可 slice(none,stop,none)

exam:

l=list(range(10))
print(l)
print(l[slice(1,6,2)])
print(l[1:8:2])
print(l[slice(5)])out:[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
[1, 3, 5]
[1, 3, 5, 7]
[0, 1, 2, 3, 4]

字符串也可以这么搞

s='abddfdfdf'
print(s[0:8:2])
print(s[slice(0,8,2)])out:
adff
adff

Python基础之内置函数(二)相关推荐

  1. python中递归函数的基例_详谈Python基础之内置函数和递归 Python递归和循环的区别...

    Python 递归函数基例 2. 关于递归函数基例的说明,以下选项中错误的是 A 递归函数的基例决定所谓基例就是不需要递归就能求解的,一般来说是问题的最小规模下的解. 例如:斐波那契数列递归,f(n) ...

  2. Python基础之内置函数

    一.内置函数 内置函数是python里自带可直接使用的函数,到python3.6共提供里68个内置函数 内置函数分6大板块: 基础数据类型:38 作用域相关:2 迭代器生成器:3 其他:12 反射:2 ...

  3. python基础之内置函数解析之二

    书接上文: 茱莉亚罗伯茨镇楼!!!! divmod(a, b) 它将两个(非复数)数字作为实参,并在执行整数除法时返回一对商和余数.对于混合操作数类型, 适用双目算术运算符的规则.对于整数,结果和 ( ...

  4. 笔记:python基础之内置函数2

    [].reverse():反转 reverse([]):反转的迭代器,能保留原序列 l = [1,2,3,4,5] l.reverse() print(l) l = [1,2,3,4,5] l2 = ...

  5. python什么元素为真_如何使用Python基础内置函数

    如何使用Python基础内置函数 发布时间:2020-08-05 13:46:59

  6. python之内置函数(二)与匿名函数、递归函数初识

    一.内置函数(二) 1.和数据结构相关(24) 列表和元祖(2) list:将一个可迭代对象转化成列表(如果是字典,默认将key作为列表的元素). tuple:将一个可迭代对象转化成元组(如果是字典, ...

  7. python D14 内置函数二

    # 内置函数二# 1.lambda匿名函数# 2.sorted()# 3.filter()# 4.map()# 5.递归函数 # 一.lambda匿名函数# 未来解决一些简单的需求而设计的一句函数# ...

  8. python学习之内置函数(二)

    4.7.3 内置函数(2) int() str() bool() set() list():将一个可迭代对象转化为列表 tuple():将一个可迭代对象转换成元组 dic(): 通过相应的方式创建字典 ...

  9. python函数递归法求一个数各位数之和_Python基础之内置函数和递归

    一.内置函数 下面简单介绍几个: 1.abs() 求绝对值 2.all() 如果 iterable 的所有元素都为真(或者如果可迭代为空),则返回 True 3.any() 如果 iterable 的 ...

  10. Python基础—内置函数、匿名函数、递归函数

    文章目录 一.内置函数 1 作用域相关 2 其他 Ⅰ 字符串类型代码的执行: Ⅱ 输入输出相关: Ⅲ 数据类型相关: Ⅳ 内存相关: Ⅴ 文件操作相关 Ⅵ 模块操作相关 Ⅶ 帮助方法 Ⅷ 调用相关 Ⅸ ...

最新文章

  1. 1.5 编程基础之循环控制 10 满足条件的数累加
  2. [转]在Visual Studio 2013/2015中设计UML活动图
  3. oracle只有oradata恢复,如何恢复一个只有完好数据文件的数据库?
  4. pytorch源码解析2——数据处理torch.utils.data
  5. Qt---MaintenanceTool
  6. (转)什么是Cookies详解
  7. access 的几种更新语句:update where 与 update join where
  8. 工行u盾显示316_工行U盾只显示金融@家怎么显密码
  9. 技术培训看这里,质谱仪,液相色谱理论实操相结合
  10. Cesium离线地图极简教程
  11. ASP.NET项目上云实践——华为云DevCloud(图书管理系统)
  12. 计算机学院王春枝教授实验室,全国高等学校计算机科学与技术教学成果获奖证书.doc...
  13. SQL Server 2008 复制 遇到: 进程无法执行 'sp_replcmds' 命令
  14. (7)centos7 同步服务器时间
  15. 生产内存溢出定位分析
  16. virtualhackinglabs靶机 ANTHONY 10.12.1.113
  17. Java 时间间隔计算工具类
  18. [python项目] 项目概述
  19. 蓝光原版与蓝光Remux格式到底有什么区别?
  20. 家庭监控系统实现(一) -- 硬件准备及picamera使用

热门文章

  1. SQL语句优化技术分析 整理他人的
  2. 为什么要Code Review
  3. Sencha Touch 心得
  4. Java:集合,Map接口框架图
  5. 【数据结构】顺序线性表的几种常用方法
  6. k8s Deployment
  7. Spring事务异常回滚
  8. c/c++ 基本线程管理 join detach
  9. Hbase启动hbase shell运行命令报Class path contains multiple SLF4J bindings.错误
  10. Thread.Join 和 Task.Wait 方法