day17 Pyhton学习 内置函数继续

1. locals 本地作用域/局部作用域  会随着位置的改变而改变

2.globals 全局作用域   永远不变,永远是全局

3.complex:复数 实数(有理数和无理数)

某一个数的平方是-1 ,那么这个数就是一个虚数的基础单位 j
# 复数 = 实数+虚数 = a+bj
# 选择题 :(对你的数学有要求的公司都会考)
    # 复数不能比较大小
    # 共轭复数 : a+bj 和 a-bj是一对共轭复数
    # a+bj 和 a+bJ都是复数

4.bin oct hex

# a = 19
# # 0 1 2 3 4 5 6 7 8 9 A B C D E F 10
# # 256 十进制
# print(bin(a))  # 0b100000000 0b代表二进制,100000000 = 256   
# print(oct(a))    # 0o400 0o代表八进制,400 = 256
# print(hex(a))    #十六进制

5.abs 求绝对值,正数的绝对值是正数,负数的绝对值也是正数

6.divmod 商余函数

print(divmod(2520,25))#(100, 20)
print(divmod(35,25))#(1, 10)
print(divmod(8,3))#(2, 2)

7.round(小数,保留几位小数)    小数精确

ret = round(2.3258358)
print(ret)#2
ret = round(2.3253358,2)
print(ret)#2.33
ret = round(2.3253358,3)
print(ret)#2.325
ret = round(0.5)
print(ret)#0

8.pow(x,y,z=1) 幂运算/幂余运算  x的y次方%2

print(pow(2,3))#8
print(pow(3,2))#9
print(pow(5,3,2))#1
print(pow(4,2,2))#0
print(pow(4,3,2))#0

9.sum(可迭代的数字集,start),start从哪个数开始加

print(sum((1,2,3,4)))
print(sum([1,2,3,4]))
print(sum(range(10)))
print(sum((i**2 for i in range(5))))
print(sum((1,2,3,4)))
print(sum((1,2,3,4),10))
print(sum((1,2,3,4),30))

10.min/max(iterable/*args,key) key是一个函数的内存地址,key做的事情就是根据你对每一项数据大小的需求来排序

print(min(1,2,3))
print(min((1,2,3)))
print(min((1,2,3),(4,5,6)))
print(min((7,2,3),(4,5,6)))
def func(n):   # n = 2,3,4,7
    return n%6 # 2,3,4,1
ret = min(2,3,4,7,key = func)
print(ret) #7
l = [{'name1':10},{'name2':500}]
def func(dic):
    for k in dic:
        return dic[k]
# def max(iter,key = None):#自己定义的max函数
#     ret=0
#     max_value = 0
#     if key:
#         for i in iter :
#             if key(i)>max_value:#key(i)是股票的价格
#                 max_value = key(i)
#                 ret = i
#     return ret
# def min(iter,key = None):#自己定义的min函数
#     ret=0
#     min_value=0
#     if key:
#         for i in iter:
#             if min_value==0:
#                 min_value=key(i)
#                 ret=i
#             elif min_value>key(i):
#                 min_value=key(i)
#                 ret=i
#     return ret
print(max(l,key = func))
print(min(l,key = func))
# l中的每一项都会作为参数传给func
# max和min的求值会根据func的返回值来排序

11.reversed(list/tuple)  #返回一个迭代器,为了节省内存

l = [1,2]
l.reverse()
print(l)

ret = reversed([1,2,3])  # iterator
print(list(ret))
# reverse是在原基础上修改 : 2000项的列表 不会产生额外的内存占用
# reversed不修改原基础 : 不直接返回列表而返回迭代器,为了不占用更多的内存

12. slice  切片

l = [1,2,3,4,5,]#[2, 3, 4]
print(l[1:4])

ret = slice(1,4)# [2, 3, 4]
print(l[ret])

13 . format  与具体数据相关,用于计算各种小数,精算等

# 字符串
print(format('test', '<20')) # 左对⻬
print(format('test', '>20')) # 右对⻬
print(format('test', '^20')) # 居中
# 数值
print(format(3, 'b')) # ⼆进制
print(format(97, 'c')) # 转换成unicode字符
print(format(11, 'd')) # ⼗进制
print(format(11, 'o')) # ⼋进制
print(format(11, 'x')) # ⼗六进制(⼩写字⺟)
print(format(11, 'X')) # ⼗六进制(⼤写字⺟)
print(format(11, 'n')) # 和d⼀样
print(format(11)) # 和d⼀样
# 浮点数
print(format(123456789, 'e')) # 科学计数法. 默认保留6位⼩数
print(format(123456789, '0.2e')) # 科学计数法. 保留2位⼩数(⼩写)
print(format(123456789, '0.2E')) # 科学计数法. 保留2位⼩数(⼤写)
print(format(1.23456789, 'f')) # ⼩数点计数法. 保留6位⼩数
print(format(1.23456789, '0.2f')) # ⼩数点计数法. 保留2位⼩数
print(format(1.23456789, '0.10f')) # ⼩数点计数法. 保留10位⼩数
print(format(1.23456789e+10000, 'F')) # ⼩数点计数法.

14. bytes 字节

# str --> bytes
# print('abc'.encode('utf-8'))
# print('你好'.encode('utf-8'))
# bytes --> str
# b = b'\xe4\xbd\xa0\xe5\xa5\xbd'
# print(b.decode('utf-8'))

15. bytearray 把一个字符串编程一个字节数组,较长的字符串的修改节省内存,修改行为必须依靠编码

ret = bytearray('abc'*30,encoding='utf-8')  # 字节数组
print(ret)#bytearray(b'abcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabc'
ret[0] = 102   # asc码  65A 97abcdef 你好 您好
print(ret)#bytearray(b'fbcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabc'

16.memoryview 查看bytes在内存中的情况

ret = memoryview(bytes('hello,eva',encoding='utf-8'))
print(list(ret[:10]))

17.ord/chr 字符和编码之间的转换

# print(ord('a'))
# print(chr(97))

18.repr() 打印的时候输出这个变量的数据类型

a = 1
b = '1'
print(repr(a),repr(b))#1  '1'
print(a)#1
print(b)#1

19.len 计算长度

a="d3d3dd"
print(len(a))#6
posted @ 2018-11-09 20:17  Python张梦书  阅读(163)  评论(0编辑  收藏  举报