• Python Built-in Function 学习笔记


    1. 匿名函数
    1.1 什么是匿名函数
    python允许使用lambda来创建一个匿名函数,匿名是因为他不需要以标准的方式来声明,比如def语句

    1.2 匿名函数优点
    节省内存:如果不把它赋值给一个变量的话,由于是匿名的,不用分配栈空间
    不会重名
    可以嵌在推导式中,代码更简练
    1.3 举例
    lambda 参数列表:返回值
    a = lambda x,y=2:x+y
    a(5) ==> 7
    a(2,3)==> 5


    2. 内置函数
    2.1 abs():返回一个数值的绝对值,参数接受整数或浮点数,如果参数是复数,返回复数的模
    2.2 all(iterable): 可迭代对象为空或者元素全为True,返回True。 类似与and
    2.3 any(iterable): 可迭代对象中有一个元素为True返回True,否则返回False
    2.4 ascii():类似repr()
    print(ascii("abc ")) #'abc '

    2.5 bin(int):
    print(bin(100)) #0b1100100
    a = bin(100)
    print(type(a)) <class 'str'> 返回值是一个字符串
    将整数转换为二进制字符串,结果是一个有效的python表达式。
    2.6 bool(x):
    bool类型是int的子类,返回布尔True或False,使用真值测试标准对x进行转换。
    print(bool("123")) --> True
    2.7 bytearray():返回一个字节数组
    source:
    如果是一个字符串,需要指定编码,以及可选的参数errors
    如果是一个可迭代对象,其整数元素取值范围0 <= x < 256
    a = bytearray("abc",encoding='utf-8',errors="失败")
    print(a,type(a)) # bytearray(b'abc') <class 'bytearray'>
    print(a[0]) # 97
    print(a[1]) # 98
    print(a[2]) # 99

    2.8 bytes(): 返回一个新的字节对象,是一个0 <= x < 256不可变的整数序列,是bytearray()不可变版本
    2.9 callable(object):
    如果object是可调用的,返回True。
    注:类是可以调用的,调用一个类会返回一个新的实例
    2.10 chr():
    ord()的逆操作,通过字符返回Unicode码值.
    print(chr(98)) #b
    2.11 classmethod():
    将函数包装成类方法。
    类方法隐式的将类作为第一个参数接收,就像实例方法接收实例一样
    2.12 compile(source, filename, mode, flags=0, dont_inherit=False, optimize=-1):
    将source编译成代码或AST对象。代码对象可以被exec()或eval()执行
    2.13 complex():
    返回复数
    2.14 delattr(object,name):
    参数:对象,字符串(必须是对象属性之一的名称),该函数实现删除对象指定属性的操作,只要改对象允许
    delattr(x,'name') ===> del x.name

    2.15 dict(): 创建一个字典。dict对象是一个字典类,可以是实例化一个字典对象
    d = dict({'a':96})
    2.16 dir([object]):
    打印:
    --> 内置方法
    --> 内置属性
    --> 对象属性
    --> 对象方法
    --> 类属性
    --> 类方法

    1. 不带参数的时候:返回当前作用域的名称列表
    2. 带参数时:返回object有效属性列表
    3. 如果对象具有__dir__()方法,将会调用此方法,并且必须返回属性列表

    I. 如果对象是模块对象:列表包含模块的属性名
    II. 如果对象是类型或者类对象,列表包含其属性名称,并显示其父类的属性的递归。
    III. 否则列表包含对象的属性名称,其类属性的名称以及其类的基类的属性的递归。

    2.17 divmod(a,b):两个整数作为参数,返回商和余组成的元组。使用的整除(商,余数)
    print(divmod(1,2)) # (0,1)
    print(divmod(4,2)) # (2,0)
    print(divmod(10,3),type(divmod(10,3))) # (3,1)<class 'tuple'>

    2.18 enumerate(iterable,start=0):
    1. 返回一个enumerate object对象,索引默认从0开始
    2. 调用enumrate object的__next__()方法,返回一个元组
    3. 该元组包含一个计数,从start开始和iterable迭代的值

    for i in enumerate([1,2,3,4],start=0):
    print(i)

    (0, 1) (start,iterable)
    (1, 2)
    (2, 3)
    (3, 4)

    2.19 eval(expression, globals=None, locals=None):
    参数是一个字符串和可选的全局变量和局部变量。
    也用于执行任意代码对象,支持语句的动态执行
    eval("print('Hello')") ---> console打印: Hello

    2.20 exec(object[, globals[, locals]):
    这个函数支持动态执行Python代码。object必须是一个字符串或代码对象。
    如果它是一个字符串,则将该字符串解析为一组Python语句,然后执行该语句(除非发生语法错误)。
    如果它是一个代码对象,只是简单地执行它。
    exec("print('Hello')") ---> console打印: Hello

    eval()和exec()区别:
    1. 如果是简单的表达是求值,eval()和exec()都可以
    2. exec()支持字符串、代码对象、复杂的Python代码
    3. eval()仅支持有效的表达式求值并返回计算结果

    2.21 filter(function, iterable): 类似表达式的过滤。比列表推导式省内存
    1. 如果function不是None,等效于生成器表达式,比列表推导式省内存
    2. 如果function是None,等效于列表推导式

    f = filter(None,shares) # 函数为None,类似列表推导式,循环打印出每一个值
    print(f,type(f)) #<filter object at 0x00000242A5C585C0> <class 'filter'>
    for i in f:
    print(i)
    '''
    IBM
    Lenovo
    ocean
    '''

    # 类似可迭代对象的过滤工具:把每一项拿出来处理
    f = filter(lambda x:shares[x]>20,shares) # 他会把每个元素拿出来,放到函数中,然后根据函数的返回值。返回一个filter对象
    print(f,type(f)) #<filter object at 0x00000242A5C585C0> <class 'filter'>
    for i in f:
    print(i)
    '''
    IBM
    Lenovo
    '''


    2.22 float():返回一个由数字或字符串x构造的浮点数。
    2.23 format(): 字符串格式化
    I.
    print("{},{},{}".format(name,age,name)) # 不可以重复,有序
    II.
    print("{0},{1},{0}".format(name,age)) # 可以重复
    III.
    print("{name},{age},{name}".format(name=name,age=age)) # 可以重复,无序
    2.24 frozenset():返回一个新的frozenset对象,可选地使用iterable中的元素。
    set(可变集合)与frozenset(不可变集合)的区别:
    set无序排序且不重复,是可变的,有add(),remove()等方法。既然是可变的,所以它不存在哈希值。基本功能包括关系测试和消除重复元素.
    frozenset是冻结的集合,它是不可变的,存在哈希值,好处是它可以作为字典的key,也可以作为其它集合的元素。缺点是一旦创建便不能更改,没有add,remove方法。
    2.25 getattr(object,name[, default]):
    返回对象命名属性的值,name必须是字符串
    如果name是对象属性之一,则该结果是该属性的值。
    getattr(x,"name") ===> x.name
    如果name不存在,则返回提供default值,否则引发AttributeError

    2.26 globals():
    返回当前全局变量名的字典
    2.27 hasattr(object,name):
    参数是一个对象和一个字符串。如果字符串是对象的一个属性,则返回True,否则返回False。
    它的实现是通过调用getattr(object, name)并查看它是否引发一个AttributeError。
    在getattr()之前判断object是否含有某个属性
    2.28 hash():
    返回该对象的哈希值(如果有的话). 哈希值应该是一个整数。
    哈希值用于在查找字典时快速地比较字典的键。
    相等数值的哈希值相同(即使它们的类型不同,比如1和1.0).

    2.29 help():调用内置的帮助系统。
    2.30 hex():将整数转换为以“0x”为前缀的小写十六进制字符串
    2.31 id(): 返回对象的内存地址
    返回一个对象的“身份”。
    这是一个整数,它保证在该对象的生命周期内是唯一的和恒定的。
    具有不重叠寿命的两个对象可以具有相同的id()值。
    2.32 input([prompt]):
    如果存在提示符参数,则将其写入标准输出而不带结尾换行符。
    然后该函数从输入中读取一行,将其转换为一个字符串(剥离尾随的换行符),然后返回该行。
    当读取到EOF时,会产生EOFError。
    input("Hello") ---> console:Hello

    2.33 int():
    从数字或字符串(x)构造并返回一个整数对象
    如果没有给出参数,则返回0。
    如果 x 是一个数字,返回 x.__int__()。对于浮点数,这将截断为零。

    2.34 isinstance(object, classinfo):
    instance(实例,类型)
    如果object是clsaainfo的一个实例(或者是classinfo的直接、间接或虚拟子类的实例),那么则返回true。
    如果object不是给定类型的对象,则该函数始终返回false。

    如果classinfo是类型对象的元组(或者其他这样的元组),如果object是任何类型的实例,则返回true。
    如果classinfo不是类型或类型组成的元祖和此类元组,则会引发TypeError异常。

    2.35 issubclass(class, classinfo):
    issubclass(类,或父类)
    如果 class 是classinfo的子类(直接、 间接或 虚拟) 则返回 true 。
    一个类被认为是它自己的一个子类。

    任何其他情况下,会引发TypeError异常。

    2.36 iter(object[, sentinel]):
    1. 返回一个迭代器对象。
    2. 根据第二个参数:
    没有第二个参数,object必须是一个支持迭代协议(__iter__()方法)的容器对象,或者它必须支持序列协议
    第二个参数sentinel,那么object必须是一个可调用的对象。 object.__next__()

    2.37 len():返回对象的长度(项目数量)。
    2.38 list():list不是一个函数,它实际上是一个可变的序列类型
    2.39 locals():更新和返回表示当前局部符号表的字典。当locals()在函数代码块中调用时会返回自由变量,但是在类代码块中不会。
    2.40 map(function, iterable, ...):
    1. 返回一个迭代器
    2. 对iterable的每个项应用function,并yield结果。
    2.41 max():
    返回iterable中的最大项或两个或更多个参数中最大的项。
    max(iterable, *[, key, default])
    max(arg1, arg2, *args[, key])
    2.42 memoryview(obj):
    返回从给定参数创建的“内存视图”对象。
    2.43 min():
    返回可迭代中的最小项或两个或更多个参数中的最小项。
    2.44 next(iterator[, default]):
    通过调用__next__()方法从迭代器中检索下一个项目。如果给出default,则在迭代器耗尽时返回,否则引发StopIteration。
    2.45 object():
    返回一个新的无特征的对象。
    该函数不接受任何的参数。
    2.46 oct():将整数转换为八进制字符串。
    2.47 open(file, mode='r', buffering=-1, encoding=None, errors=None, newline=None, closefd=True, opener=None):
    打开 file 并返回一个相应的 文件对象.如果文件不能被打开, 抛出 OSError 异常.

    2.48 ord():
    给定一个表示一个Unicode字符的字符串,返回一个表示该字符的Unicode代码点的整数。

    2.49 pow():返回x的y次方; 如果提供z参数, 返回x 的y次方再除以z的余数
    2.50 print(*objects, sep=' ', end=' ', file=sys.stdout, flush=False):
    1. 将object打印到文本流file,由sep分隔,尾部接end。
    2. sep, end 和 file 如果提供这三个参数的话,必须以关键参数的形式。
    2.51 property():返回一个property 属性。
    class Person(object):
    def __init__(self,name,age):
    self.name = name
    self.age = age

    def gettx(self):
    return self.name

    def setx(self,name):
    self.name=name

    def delx(self):
    del self.name
    x = property(gettx, setx, delx, "I'm the 'x' property.")

    p = Person(name,age)

    # 和@property一样。自定义托管属性
    print(p.x)
    p.x="haha"
    del p.x
    2.52 range():
    range(stop)
    range(start, stop[, step])
    range实际上是一个不可变的序列类型
    2.53 repr():
    返回一个包含对象可打印表示的字符串。
    一个类可以通过定义一个__repr__()方法来控制该函数为其实例返回的内容。
    2.54 reversed(seq):
    返回一个反向iterator。seq必须是具有__reversed__()方法或支持序列协议(__len__()方法和__getitem__()方法,整数参数从0开始)。
    2.55 round(number[, ndigits]):
    四舍五入
    返回number舍入到小数点后ndigits位的浮点值。如果省略ndigits,将返回最接近输入的整数。
    2.56 set():
    返回一个新的set对象,可选地使用iterable中的元素。
    2.57 setattr():
    它与getattr()相对应。参数是一个对象、一个字符串和一个任意值。
    该字符串可以命名现有的属性或新的属性。
    如果该对象允许,该函数将该值分配给该属性。
    setattr(x, 'foobar', 123)等同于x.foobar = 123

    2.58 slice():
    class slice(stop)
    class slice(start, stop[, step])
    返回表示由范围(start, stop, step)指定的一组索引的slice对象 T2>。


    2.59 sorted(iterable[, key][, reverse]):依据iterable中的元素返回一个新的排好序的列表。
    iterable[, key][, reverse]
    key指示一个带有一个参数的函数,它用于从列表的每个元素中提取比较的关键字:key=str.lower
    reverse是一个布尔值。如果设置为True,那么列表中元素反过来比较来排序。


    2.60 staticmethod():
    为函数返回一个静态方法。
    2.61 str():
    返回一个object的str版本
    repr:对象以str形式表现出来,以便辨认
    2.62 sum(iterable[, start]):
    从左至右项目返回总数
    连接字符串序列的首选方法是通过调用''.join(sequence)的方式
    2.63 super(type[, object-or-type]):
    返回一个调用父类或者type同级类的委托方法
    访问类中被覆盖的继承方法时很有用
    1. 在单继承中,super()和其他编程语言类似,使用super()来引用父类,而不必明确命名它们
    2. 动态执行环境中,支持协同多继承。


    2.64 tuple([iterable]):
    tuple实际上是一个不可变的序列类型,而不是一个函数
    2.65 type():
    class type(object)
    class type(name, bases, dict)

    使用一个参数,返回对象的类型。
    返回值是一个类型对象,并且通常与object.__class__返回的对象相同。
    建议使用isinstance()内置函数来测试对象的类型,因为它考虑了子类。
    有三个参数,返回一个新的类型对象。这本质上是class语句的动态形式。

    2.66 vars([object]):
    返回一个模块、字典、类、实例或者其它任何一个具有__dict__属性的对象的__dict__属性。
    2.67 zip(*iterables):
    创建一个迭代器,聚合来自每个迭代器的元素。
    返回一个由元组构成的迭代器
    当最短的输入迭代耗尽时,迭代器停止。 以短的为标准

    zip()当迭代器元素不一致时,循环停止在较短的迭代器元素,较长的迭代器元素会被舍弃。
    zip()结合*运算符可用于解压缩列表

    2.68 __import__():
    通过 import 语句调用此函数。
  • 相关阅读:
    webapi支持session
    webapi返回数据同时支持xml与json
    webapi权限控制
    Asp.net 将js文件打包进dll 方法
    All Media to FLV asp.net在线视频自动转换并截图调试成功!
    未能从程序集“System.ServiceModel
    [javascript]浮动广告
    [python]multi thread tcp connect port scanner
    [vc]让你Y的用YY
    [python]扫描网站后台脚本
  • 原文地址:https://www.cnblogs.com/weihengblog/p/9090702.html
Copyright © 2020-2023  润新知