zoukankan      html  css  js  c++  java
  • 内置函数

    1. 内置函数

    就是python给你提供的. 拿来直接用的函数, 比如print., input等等. 截止到python版本3.6.2 python一共提供了68个内置函数. 他们就是python直接提供给我们的.

    abs() dict() help() help() 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()  

    作用域相关:

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

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

    迭代器相关:   

    range()       生成数据   

    next()迭代器向下执行一次, 内部实际使用了__next__()方法返回迭代器的下一个项目   

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

    字符串类型代码的执行:

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

    s=input("请输入a+b:")
    print(eval(s))
    5+5
    结果:10
    s="25*4"
    print(eval(s))
    
    100

     

    s="for i in range(10): print(i)"
    print(eval(s))    
    
    结果:报错

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

    s="for i in range(10): print(i)"
    print(exec(s))
    0
    1
    2
    3
    4
    5
    6
    7
    8
    9
    None
    # 动态执行代码
    exec("""
    def func():
        print(" 我是周杰伦")
    """ )
    func()
    
    我是周杰伦

    区别:一个执行简易的,一个执行复杂点的!

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

    code1 = "for i in range(10): print(i)"
    com = compile(code1, "", mode="exec")   # compile并不会执行你的代码.只是编译
    exec(com)   # 执行编译的结果
    0
    1
    2
    3
    4
    5
    6
    7
    8
    9
    code2 = "5+6+7"
    com2 = compile(code2, "", mode="eval")
    print(eval(com2))
    18
    code3 = "name = input('请输入大阳哥的名字:')"
    com3 = compile(code3, "", mode="single")
    exec(com3)
    print(name)

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

    输入和输出相关:   

    input()    获取用户输入的内容   

    print()    打印输出

    内存相关:   

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

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

    文件操作相关:   

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

    模块相关:   

    __import__()    用于动态加载类和函数   <=> import  os

    name = input("请输入你要导入的模块:")
    __import__(name)    # 可以动态导入模块

    帮助:   

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

    print(help(str))

    调⽤相关:   

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

     dir()    查看对象的内置属性, 方法. 访问的是对象中的__dir__()⽅方法 基础数据类型相关:

    print(dir(str))

    
    

    数字相关:        

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

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

    float()  将给定的数据转换成float值. 也就是小数       

    complex()  创建一个复数. 第一个参数为实部, 第二个参数为虚部. 或者第一个参数直接用字符串来描述复数

    进制转换:       

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

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

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

    数学运算:       

    abs()            返回绝对值   

    print(abs(-2))
    2

    divmode()     返回商和余数  

    print(divmod(100,3))
    (33, 1)

    round()        四舍五入 

    print(round(4.6))
    5

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

    print(pow(10,2))
    100
    print(pow(10,2,3))
    1

    sum()    求和 

    print(sum([1,2,3,4,5,6,7,8,9,10]))
    55

    min()    求最⼩小值       

    max()    求最⼤大值

    和数据结构相关:   

    列表和元组:       

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

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

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

    lst = "你好啊"
    it = reversed(lst)   # 不会改变原列表. 返回一个迭代器, 设计上的一个规则
    print(list(it))
    ['', '', '']

    slice()    列表的切片

    lst = [1, 2, 3, 4, 5, 6, 7]
    print(lst[1:3:1])
    [2, 3]
    s = slice(1, 3, 1) 
    print(lst[s])
    [2, 3]

    字符串相关:       

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

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

    s="今天星期四"
    print(format(s,"^20"))
    print(format(s,"<20"))
    print(format(s,">20"))
           今天星期四        
    今天星期四               
                   今天星期四
    print(format(3, 'b' ))   # ⼆进制
    print(format(97, 'c' ))   # 转换成unicode字符
    print(format(11, 'd' ))   # ⼗进制 %d
    print(format(11, 'o' ))   # ⼋进制  8
    print(format(11, 'x' ))   # ⼗六进制(⼩写字⺟)
    print(format(11, 'X' ))   # ⼗六进制(⼤写字⺟)
    print(format(11, 'n' ))   # 和d⼀样
    print(format(11))   # 和d⼀样

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

    s="下雨"
    print(s.encode("utf-8"))
    bs=b'xe4xb8x8bxe9x9bxa8'
    print(bs.decode("utf-8"))

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

    ret =  bytearray("alex" ,encoding ='utf-8')
    print(ret[0])
    ret[0] = 65
    print(str(ret))
    97
    bytearray(b'Alex')

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

    s = memoryview("麻花藤".encode( "utf-8")) # 查看内存
    print(s)
    <memory at 0x0000026A980DB4C8>

     ord()    输入字符找带字符编码的位置       

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

    ascii()  是ascii码中的返回该值不是就返回u...

    print(ord('a')) # 97, 返回字母a在编码表中的码位
    print(ord('')) # 20013 中国的中字在编码表中的位置
    print(chr(65)) # 已知码位. 计算字符
    print(chr(20018))
    print(ascii(""))
    'u623f'

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

    name = "你好. 
    我叫%s周润发" % "李嘉诚"
    print(name)
    print(repr(name))   # 原样输出,过滤掉转义字符 
     	 
     不管百分号
    你好. 
    我叫李嘉诚周润发
    '你好. 
    我叫李嘉诚周润发'

     数据集合:       

    dict()    创建一个字典

    set()     创建一个集合       

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

    其他相关:        

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

    sorted()    对可迭代对象进行排序操作(讲完lamda后再讲这个)       

    enumerate()    获取集合的枚举对象

    lst=["sd","发斯蒂芬是否","asdafa"]
    for index, el in enumerate(lst, 100):    # 把索引和元素一起获取,索引默认从0开始. 可以更改
        print(index)
        print(el)
    100
    sd
    101
    发斯蒂芬是否
    102
    asdafa

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

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

    print(all([1, "哈哈", "馒头", True]))
    print(any([0, "哈哈", "馒头", True]))
    True
    True

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

    lst1 = ["施瓦辛格", "泰达米尔", "阿米尔汗", "威震天"]
    lst2 = ["终结者", "英雄联盟", "我的个神啊", "变形金刚"]
    lst3 = [10000000, 3, 10, 55,66]
    for el in zip(lst1, lst2, lst3):
        print(el)
    ('施瓦辛格', '终结者', 10000000)
    ('泰达米尔', '英雄联盟', 3)
    ('阿米尔汗', '我的个神啊', 10)
    ('威震天', '变形金刚', 55)

     filter()     过滤

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

     参考资料:

  • 相关阅读:
    Ehcache(2.9.x)
    Ehcache(2.9.x)
    Ehcache(2.9.x)
    Ehcache(2.9.x)
    Ehcache(2.9.x)
    Ehcache(2.9.x)
    Ehcache(2.9.x)
    网站静态化处理—反向代理(10)
    网站静态化处理—满足静态化的前后端分离(9)
    网站静态化处理—前后端分离—下(8)
  • 原文地址:https://www.cnblogs.com/chenyibai/p/9338532.html
Copyright © 2011-2022 走看看