内置函数

内置函数就是python提供的,可以直接拿来用的函数,如print,input等都是内置函数.

作用域相关:

  locals()  返回当前作用域中的名字

  globals()  返回全局作用域中的名字

迭代器相关:

  range()  生成数据

  next()  迭代器向下执行一次,内部实际使用了__next__()方法来获取迭代器的下一个值

  iter()  获取迭代器,内部实际使用的是__iter__()方法来获取迭代器

字符串类型代码的执行:

  eval()  执行字符串类型的代码,并返回最终结果

print(eval("2+2"))  # 4 
n = 8 
print(eval("2+n"))  # 10 
def func():
    print(666) 
eval("func()")  # 666 

  exec()  执行字符串类型的代码

exec(""" 
for i in range(10):
    print(i) 
""") 
exec(""" 
def func():
    print("我是周杰伦") 
func() 
""")

  compile()  将字符串类型的代码编译,代码对象能够通过exec语句来执行或者eval()进行求值

'''
    参数说明 :
        1. resource要执行的代码 , 动态代码片段
        2. 文件名 , 代码存放的文件名 , 当传入了第一个参数的时候 , 这个参数给空就可以了
        3. 模式 , 取值有 3 个 ,
           1. exec: 一般放⼀些流程语句的时候 
           2. eval: resource 只存放一个求值表达式 .
           3. single: resource 存放的代码有交互的时候 . mode 应为 single
''' 
code1 = "for i in range(10): print(i)" 
c1 = compile(code1, "", mode="exec") 
exec(c1) 

code2 = "1+2+3" 
c2 = compile(code2, "", mode="eval")
a = eval(c2)
print(a) 

code3 = "name = input('请输⼊入你的名字:')" 
c3 = compile(code3, "", mode="single") 
exec(c3) 
print(name)

  有返回值的字符串形式的代码用eval().没有返回值的字符串形式的代码用exec().一般很少用compile()

输入和输出相关:

  input()  获取用户输入的内容,获取到的数据类型为str

  print()  打印输出

内存相关:

  hash()  获取到对象的哈希值(int,str,bool,tuple)

  id()     获取到对象的内存地址

文件操作相关:

  open()  用于打开一个文件,创建一个文件句柄

模块相关:

  __import__() 用于动态加载类和函数

帮助:

  help()  用于查看函数或模块的详细说明

调用相关:

  callable()  用于检查一个对象是否可调用,如果返回True,object有可能调用失败,如果返回False,调用绝对不会成功.

查看内置属性:

  dir()  查看内置属性,方法,访问的对象中的__dir__()方法

基础数据类型相关:

  数字相关:

    bool()  将给定的数据转换成bool值,如果不给值,返回False

    int()     将给定的数据转换成int值,如果不给值,返回0

    float()  将给定的数据转换成float值,小数

    complex()  创建一个复数,第一个参数为实部,第二个参数为虚部,或者第一个参数直接用

 字符串来描述复数

  进制转换:

    bin()  将给的参数转换成二进制

    otc()  将给的参数转换成八进制

    hex()  将给的参数转换成十六进制

  数学运算:

    abs()  返回绝对值

    divmode()  返回商和余数

    round()  四舍五入

    pow(a,b)  求a的b次幂,如果有三个参数,则求完次幂后对第三个数取余

    sum()  求和

    min()  求最小值

    max()  求最大值

数据结构相关:

  列表和元组:

    list()  将一个可迭代的对象转换成列表

    tuple()  将一个可迭代的对象转换成元组

    reversed()  讲一个序列翻转,返回翻转序列的迭代器

    slice()  列表的切片

st = "大家好, 我是麻花藤" 
s = slice(1, 5, 2) 
print(st[s]) 

字符串相关:

  str()  将数据转换成字符串

  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'))   # 小数点计数法.

  bytes()  把字符串转换成bytes类型

s = "你好" 
bs = s.encode("UTF-8") 
print(bs) 
s1 = bs.decode("UTF-8") 
print(s1) 

bs = bytes(s, encoding="utf-8")     # 把字符串编码成UTF-8 
print(bs)

  bytearray()  返回一个新字节数组,这个数字里的元素是可变的,并且每个元素的值的范围是[0,256]

  

ret = bytearray('alex',encoding='utf-8') 
print(ret[0]) 
print(ret) 

  memoryview()  查看bytes在内存中的情况

# 查看bytes字节在内存中的情况 
s = memoryview("麻花藤".encode("utf-8")) 
print(s) 

  ord()  输入字符找出在ascii码中的编码位置

  chr()  输入数字找出对应的ascii字符

  ascii()   是ascii码就返回该值,不是就返回\u...

# 找到对应字符的编码位置 
print(ord('a')) 
print(ord('中')) # 找到对应编码位置的字符 
print(chr(97)) 
print(chr(20013)) # 在ascii中就返回这个值. 如果不在就返回\u... 
print(ascii('a')) 
print(ascii('好')) 

  repr()  返回一个对象的string形式

# repr 就是原封不动的输出, 引号和转义字符都不起作用 
print(repr('大家好,\n \t我叫周杰伦')) 
print('大家好我叫周杰伦') 
# %r 原封不动的写出来 name = 'taibai' print('我叫%r' % name)

  数据集合:

    dict()  创建一个字典

    set()  创建一个集合

    frozenset()  创建一个冻结的集合.冻结的集合不能进行添加和删除操作.

  其他相关:

    len()  返回一个对象的元素个数

    sorted()  对可迭代对象进行排序操作

    enumerate()  获取枚举对象

lst = ["alex", "wusir", "taibai"] 
for index, el in enumerate(lst):
    print(str(index)+"==>"+el) 

    all()  可迭代对象中全部都是True,结果才是True

    any()  可迭代对象中有一个是True,结果就是True

print(all([1,2,True,0])) 
print(any([1,'',0])) 

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

l1 = [1,2,3,] 
l2 = ['a','b','c',5] 
l3 = ('*','**',(1,2,3)) 
for i in zip(l1,l2,l3):
    print(i) 

    filter()   过滤

    map()  根据提供的函数对指定的序列做映射(lamda)

  

 

posted @ 2018-08-14 19:17  Virous1887  阅读(226)  评论(0编辑  收藏  举报