Python笔记_第四篇_高阶编程_再议装饰器和再议内置函数

1. 概述

  我们在前面用了很多的装饰器这个工具的方法。这个位置要系统的讲一下装饰器。

  1.2 为什么需要装饰器。

  装饰器本质是一个Python函数,它可以让其他函数在不需要任何代码变动的前提下增加额外功能,装饰器的返回值也是一个函数对象。它经常用于有切面需求的场景,比如:插入日志、性能测试、事务处理、缓存、权限校验等场景。装饰器是解决这类问题的绝佳设计,有了装饰器,我们就可以抽离出大量与函数功能本身无关的雷同代码并继续重要。

  概括的讲,装饰器的作用就是为已经存在的函数或端详添加额外的功能。  

 

2.装饰器的分类

  装饰器分自定义装饰器、内置装饰器、调用第三方模块的装饰器和多层装饰器和嵌套装饰器。

  2.1 自定义装饰器

  请参照连接,第七部分的内容:https://www.cnblogs.com/noah0532/p/10817496.html

  2.2 内置装饰器

  内置装饰器和自定义装饰器原理是一样的,不过返回的不是函数,而是类对象。其中关于@staticmethod,@classmethod,@property,@setter这四种方法在前面已经经过了,参照连接:https://www.cnblogs.com/noah0532/p/10926966.html。还有一些内置装饰器在文章的后面会补充进来。

  2.3 调用第三方模块的装饰器

    decorate.py模块

from decorator import decorate
import datettime
def wrapper(func, *args, **kwargs):
    """print log before a function."""
    print (" {}: enter {}()".format(datetime.datettime.now(), func.__name__))
    return func(*args, **kwargs)

def logging(func):
    return decorate(func, wrapper)  # 用wrapper装饰func

 

    decorator.py模块:注意这个包没有安装的话需要安装这样一个包。py3.7版本是默认安装的。

    这是一个非常简单的装饰器加强包。可以很直观的包装函数rapper(),再使用decorate(func,wrapper)方法就可以完成一个装饰器。

from decorator import decorator

@decorator
def hint(func, *args, **kwargs):
    print('{} is running'.format(func.__name__))
    return func(*args, **kwargs)

@hint
def hello():
    print("Hello!")

hello()
#hello is running
#Hello!

  备注:在这里我们看出@decorator指定如下的部分为装饰器内容,然后装饰器设定好之后,@设定好的装饰器名去装饰你想要装饰的函数。

 

    wrap.py模块

  先看实例1:

from functools import wraps

def hint(func):
    @wraps(func)
    def wrapper(*args, **kwargs):
        print('{} is running'.format(func.__name__))
        return func(*args, **kwargs)
    return wrapper


@hint
def hello():
    print("Hello!")

# hello()

  说明:raps方法对func变量进行了wraps的操作,wraps原意为包裹,表示包裹了入下的变量。比decorator更简单一点儿表示只处理其中的一部分。

  实例2:编写一个带参数的高级装饰器:

from functools import wraps


def hint(coder):
    def wrapper(func):
        @wraps(func)
        def inner_wrapper(*args, **kwargs):
            print('{} is running'.format(func.__name__))
            print('Coder: {}'.format(coder))
            return func(*args, **kwargs)
        return inner_wrapper
    return wrapper


@hint(coder="John")
def hello():
    print("Hello!")

 

  2.4 其他内置装饰器

    * @dataclass装饰器

    这个装饰器比较新,是发布于Py3.7版本的一个装饰器。

    大多数Py开发人员编写过很多像项目的类:

class MyClass:
    def __init__(self,var_a,var_b):
    self.var_a = var_a
    self.var_b = var_b

    dataclass可以为简单的情况自动生成方法,例如一个init构造方法接受这些参数并将其分配给自己,之前的小例子可以重写为。

@dataclass
class MyClass:
    var_a:str
    var_b:str

    因此:@dataclass的作用是可以声明一个类为数据类。需要导入三方库from dataclasses import dataclass,因此它具有几个方面的作用。

 

  作用1:初始化:__init__

  要实现初始化(构造函数)__init__的功能

  我们采用一种最传统的方式:

class Person(object):
    def __init__(self, name, age):
        self.name = name
        self.age = age

p = Person("Thomas",18)

print(p.name)
print(p.age)
# Thomas
# 18

  我们在采用dataclass的方式:

from dataclasses import dataclass

@dataclass()
class Person(object):
    name:str
    age:int

p = Person("Thomas",18)

print(p.name)
print(p.age)
# Thomas
# 18

  说明:看到没有用这个装饰器实现了初始化的方法。

 

  作用2:对象的暗示:__repr__/__str__

from dataclasses import dataclass

@dataclass()
class Person(object):
    name:str
    age:int

p = Person("Thomas",18)

print(p.name)
print(p.age)
# Thomas
# 18
print(Person)
# <class '__main__.Person'>

  说明:对于dataclass类而言__repr函数会自动生成,不需要显示的显示该体例

 

  作用3:对象的比较:__eq__/__lt__

  原始的方式:

# 原始方式
class Person(object):
    def __init__(self, name = "jim", age = 20):
        self.name = name
        self.age = age

    def __eq__(self, other):
        return self.name == other.name

    def __lt__(self, other):
        return self.name < other.name

  dataclass方式:

@dataclass(order = True)

  说明:表述order=True,浙西比较体例会自动实现。

  

  完整的@dataclass装饰器

  @dataclass(init=True,repr=True,eq=True,order=false,unsafe_hash=False,frozen=false)

  init:默认是True,生成__init__函数,设置为False进制生成__init__体例,表示为__slots__的体例。

  repr:默认是True,生成__repr__函数。

  eq:默认是True,生成__eq__函数。如果未生成__eq__对象进行比较,object对象的__eq__体例会被挪用。

  order:默认为False,设置为True,会生成__gt__,ge,lt,__le__体例。

  forzen:morning情况下为False,如果设置为True数据对象就是一个只读对象。dataclass装饰器会为数据生成__setattr__和__deattr__体例,试图修改对象时触发一个FrozenInstanceError。

  unsafe_hash:默认值为False,将根据eq和frozen的设置情况来决定是否生成__hash__体例。

 

  作用4:初始化后措施(Post init processing)

  数据类自动生成__init__体例,可以这也损失了一些灵活性。例如我们当我们完成初始化后需要做一些特定逻辑的情况。我们举一个简单的例子,加入我们需要在对象建立后打印一条log。

classPerson:
def__init__(self, name = "jim", age = 20):
self.name = nam
self.age = age
print("Person is created")

  幸运的是初始化后已经被考虑到了,自动生成__init__体例在执行完成后会挪用__post_init__体例。所有的初始化可以放到这个函数里面。

@dataclass
classPerson:
name: str
age: int
def__post_init__(self):
print("Person is created")

  

  作用5:继承

  数据类可以向普通类一样继承,通过继承子类便具有了父类界说的属性。

@dataclass
classPerson:
name: str
age: int
@dataclass
classStudent(Person):
grade: int

  在继承的情况下__post_init__的行为是什么呢?

@dataclass
classA:
a: int
def__post_init__(self):
print("A")
@dataclass
classB(A):
b: int
def__post_init__(self):
print("B")

  这个例子中,只有打印B的__post_init__被挪用。如果我们需要诺亚A的__post_init__该怎么办?因为他是一个父类函数,所以我们可以使用父类函数来挪用。

@dataclass
classB(A):
b: int
def__post_init__(self):
super().__post_init__()
print("B")
>>> a = B(1,2)
>>> A
B

 

  * @abstractclass虚拟类装饰器

    在像C#这样的语言中,虚拟类是保留了函数名,是一个虚方法,然后在子类当中去实现。在Py中也是这样。需要导入一个abc库

from abc import abstractmethod

class A(object):
    @abstractmethod
    def test(self):
        pass

class B(A):
    def test_1(self):
        print("未覆盖父类abstractmethod")

class C(A):
    def test(self):
        print("覆盖父类abstractmethod") # 虚方法的实现,进行重写,不是重载

if __name__ == '__main__':
    a = A()
    b = B()
    c = C()
# 前两个分别报错如下:
a = A()
# TypeError: Can't instantiate abstract class A with abstract methods test

b = B()
# TypeError: Can't instantiate abstract class **B** **with** **abstract** **methods** **test**
# 第三个实例化是正确的

 

3. 内置函数

  Python解释器内置了很多函数和类型,共有68个,加上前面的dataclass一共为69个(官方没有给出dataclass这个内置函数,暂且列入进来),如上是根据Py官方文档3.7.3提供的表格。

  3.1 内置函数表:

 

  内置函数 
abs()delattr()hash()memoryview()set()
all()dict()help()min()setattr()
any()dir()hex()next()slice()
ascii()divmod()id()object()sorted()
bin()enumerate()input()oct()staticmethod()
bool()eval()int()open()str()
breakpoint()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() 

 

 

1. abs(x)

  解释:返回一个数的绝对值。实参可以是整数或浮点数。如果实参是一个复数,返回它的模。

print(abs(-4))
print(abs(-1.2))
print(abs((1+2j)))
# 4
# 1.2
# 2.23606797749979
# 数学中的复数的模。将复数的实部与虚部的平方和的正的平方根的值称为该复数的模。
# |z|=√a^2+b^2

 

2. all(iterable)

  解释:如果 iterable 的所有元素为真(或迭代器为空),返回 True 。等价于:

  函数原型:

def all(iterable):
    for element in iterable:
        if not element:
            return False
    return True

  应用:

print(all([1,2,3,4,5]))
# True
print(all([]))
# True

 

3. any(iterable)

  解释:如果*iterable*的任一元素为真则返回``True``。如果迭代器为空,返回``False``。等价于:

  函数原型:

def any(iterable):
    for element in iterable:
        if element:
            return True
    return False

  应用:

print(any([1,2,3,4,5]))
# True
print(any([[]]))
# False

 

4. ascii(object)

  解释:就像函数 repr(),返回一个对象可打印的字符串,但是 repr() 返回的字符串中非 ASCII 编码的字符,会使用 \x、\u 和 \U 来转义。生成的字符串和 Python 2 的 repr() 返回的结果相似。ascii对照表:https://www.cnblogs.com/noah0532/p/10930131.html。其实这就是用ascii编码的方式返回一个字符串。

   应用:

print(ascii('Thomas'))
asc = ascii('Thomas')
print(type(asc))
# 'runoob'
# <class 'str'>

 

5. bin(x)

  解释:将一个整数转变为一个前缀为“0b”的二进制字符串。结果是一个合法的 Python 表达式。如果 x 不是 Python 的 int 对象,那它需要定义 __index__() 方法返回一个整数。一些例子:

  应用:

print(bin(3))
print(bin(-10))
# 如果不一定需要前缀“0b”,还可以使用如下的方法。
print(format(14, '#b'))
print(format(14, 'b'))
# 0b11
# -0b1010
# 0b1110
# 1110

 

6. class bool([x])

  解释:返回一个布尔值,True 或者 False。 x 使用标准的 真值测试过程 来转换。如果 x 是假的或者被省略,返回 False;其他情况返回 True。bool 类是 int 的子类(参见 数字类型 --- int, float, complex)。其他类不能继承自它。它只有 False 和 True 两个实例)。

在 3.7 版更改: x 现在只能作为位置参数。

   应用:

bool()
# False
bool(0)
# False
bool(1)
# True
bool(2)
# True
issubclass(bool, int)  # boolint 子类
# True

  备注:其实我们在函数返回值当中也可以用return 0,return-1等,也就等价于:1.如果返回值为0=False,2.如果返回值为其他任意数字=True

 

7. breakpoint(*args, **kws)

  解释:此函数会在调用时将你陷入调试器中。具体来说,它调用 sys.breakpointhook() ,直接传递 args 和 kws 。默认情况下, sys.breakpointhook() 调用 pdb.set_trace() 且没有参数。在这种情况下,它纯粹是一个便利函数,因此您不必显式导入 pdb 且键入尽可能少的代码即可进入调试器。但是, sys.breakpointhook() 可以设置为其他一些函数并被 breakpoint() 自动调用,以允许进入你想用的调试器。这种操作也叫断点操作,一般很少用。都是IDE编辑器手工断点调试。

import sys
sys.breakpointhook()

 

8. class bytearray([source[, encoding[, errors]]])

  解释:返回一个新的 bytes 数组。 bytearray 类是一个可变序列,包含范围为 0 <= x < 256 的整数。它有可变序列大部分常见的方法,见 可变序列类型 的描述;同时有 bytes 类型的大部分方法,参见 bytes 和 bytearray 操作。3.7 新版功能。

  可选形参 source 可以用不同的方式来初始化数组:

  如果是一个 string,您必须提供 encoding 参数(errors 参数仍是可选的);bytearray() 会使用 str.encode() 方法来将 string 转变成 bytes。

  如果是一个 integer,会初始化大小为该数字的数组,并使用 null 字节填充。

  如果是一个符合 buffer 接口的对象,该对象的只读 buffer 会用来初始化字节数组。

  如果是一个 iterable 可迭代对象,它的元素的范围必须是 0 <= x < 256 的整数,它会被用作数组的初始内容。

  如果没有实参,则创建大小为 0 的数组。

  应用:

a = bytearray('青岛', 'utf-8')
print(a)
# bytearray(b'\xe9\x9d\x92\xe5\xb2\x9b')
b = bytearray()
print(b)
# bytearray(b'')
c = [1,4,5,7,8]
print(bytearray(c))
# bytearray(b'\x01\x04\x05\x07\x08')

 

9. class bytes([source[, encoding[, errors]]])

  解释:返回一个新的“bytes”对象, 是一个不可变序列,包含范围为 0 <= x < 256 的整数。bytes 是 bytearray 的不可变版本 - 它有其中不改变序列的方法和相同的索引、切片操作。因此,构造函数的实参和 bytearray() 相同。字节对象还可以用字面值创建,参见 字符串和字节串字面值。

  应用:

a = bytes('青岛', 'utf-8')
print(a)
# b'\xe9\x9d\x92\xe5\xb2\x9b'
b = bytes()
print(b)
# b''
c = [1,4,5,7,8]
print(bytes(c))
# b'\x01\x04\x05\x07\x08'

 

10.  callable(object)

  解释:如果实参 object 是可调用的,返回 True,否则返回 False。如果返回真,调用仍可能会失败;但如果返回假,则调用 object 肯定会失败。注意类是可调用的(调用类会返回一个新的实例)。如果实例的类有 __call__() 方法,则它是可调用。3.2 新版功能: 这个函数一开始在 Python 3.0 被移除了,但在 Python 3.2 被重新加入。

   应用:

callable(0)
# False

callable("Thomas")
# False

def aaa():
    pass
callable(aaa)
# True

class A:
    def method(self):
        return 0
callable(A)
# True

a = A()
callable(a)
# False

class B:
    def __call__(self):
        return 0

callable(B)
# True
b = B()
callable(b)
# True

 

11. chr(i)

  解释:返回 Unicode 码位为整数 i 的字符的字符串格式。例如,chr(97) 返回字符串 'a',chr(8364) 返回字符串 '€'。这是 ord() 的逆函数。实参的合法范围是 0 到 1,114,111(16 进制表示是 0x10FFFF)。如果 i 超过这个范围,会触发 ValueError 异常。

   应用:

print(chr(8364))
# €

 

12. @classmethod

  解释:把一个方法封装成类方法。一个类方法把类自己作为第一个实参,就像一个实例方法把实例自己作为第一个实参。请用以下习惯来声明类方法:

  class C:

      @classmethod

      def f(cls, arg1, arg2, ...): ...

  @classmethod 这样的形式称为函数的 decorator -- 详情参阅 函数定义。类方法的调用可以在类上进行 (例如 C.f()) 也可以在实际上进行 (例如 C().f())。 其所属类以外的类实例会被忽略。 如果类方法在其所属类的派生类上调用,则该派生类对象会被作为隐含的第一个参数被传入。类方法与 C++ 或 Java 中的静态方法不同。 如果你需要后者,请参阅 staticmethod()。

  应用:https://www.cnblogs.com/noah0532/p/10926966.html

 

13. compile(source, filename, mode, flags=0, dont_inherit=False, optimize=-1)

  解释:将 source 编译成代码或 AST 对象。代码对象可以被 exec() 或 eval() 执行。source 可以是常规的字符串、字节字符串,或者 AST 对象。参见 ast 模块的文档了解如何使用 AST 对象。

  filename 实参需要是代码读取的文件名;如果代码不需要从文件中读取,可以传入一些可辨识的值(经常会使用 '<string>')。

  mode 实参指定了编译代码必须用的模式。如果 source 是语句序列,可以是 'exec';如果是单一表达式,可以是 'eval';如果是单个交互式语句,可以是 'single'。(在最后一种情况下,如果表达式执行结果不是 None 将会被打印出来。)

  可选参数 flags 和 dont_inherit 控制在编译 source 时要用到哪个 future 语句。 如果两者都未提供(或都为零)则会使用调用 compile() 的代码中有效的 future 语句来编译代码。 如果给出了 flags 参数但没有 dont_inherit (或是为零) 则 flags 参数所指定的 以及那些无论如何都有效的 future 语句会被使用。 如果 dont_inherit 为一个非零整数,则只使用 flags 参数 -- 在调用外围有效的 future 语句将被忽略。

  Future 语句使用比特位来指定,多个语句可以通过按位或来指定。具体特性的比特位可以通过 __future__ 模块中的 _Feature 类的实例的 compiler_flag 属性来获得。

  optimize 实参指定编译器的优化级别;默认值 -1 选择与解释器的 -O 选项相同的优化级别。显式级别为 0 (没有优化;__debug__ 为真)、1 (断言被删除, __debug__ 为假)或 2 (文档字符串也被删除)。

  如果编译的源码不合法,此函数会触发 SyntaxError 异常;如果源码包含 null 字节,则会触发 ValueError 异常。如果您想分析 Python 代码的 AST 表示,请参阅 ast.parse()。

  注解 在 'single' 或 'eval' 模式编译多行代码字符串时,输入必须以至少一个换行符结尾。 这使 code 模块更容易检测语句的完整性。

  警告 在将足够大或者足够复杂的字符串编译成 AST 对象时,Python 解释器有可以因为 Python AST 编译器的栈深度限制而崩溃。

  在 3.2 版更改: 允许使用 Windows 和 Mac 的换行符。在 'exec' 模式不再需要以换行符结尾。增加了 optimize 形参。

  在 3.5 版更改: 之前 source 中包含 null 字节的话会触发 TypeError 异常。

  应用:

#compile()
str = "for i in range(0,10): print(i)"
c = compile(str,'','exec')   # 编译为字节代码对象
exec(c)                          # 执行
 
str2 = "3*x + 4*y"
c2 = compile(str2, '', 'eval')  # 编译为表达式

 

14. class complex([real[, imag]])

  解释:返回值为 real + imag*1j 的复数,或将字符串或数字转换为复数。如果第一个形参是字符串,则它被解释为一个复数,并且函数调用时必须没有第二个形参。第二个形参不能是字符串。每个实参都可以是任意的数值类型(包括复数)。如果省略了 imag,则默认值为零,构造函数会像 int 和 float 一样进行数值转换。如果两个实参都省略,则返回 0j。

  注解 当从字符串转换时,字符串在 + 或 - 的周围必须不能有空格。例如 complex('1+2j') 是合法的,但 complex('1 + 2j') 会触发 ValueError 异常。

  数字类型 --- int, float, complex 描述了复数类型。

  在 3.6 版更改: 您可以使用下划线将代码文字中的数字进行分组。

   应用:略

 

15. delattr(object, name)

  解释:setattr() 相关的函数。实参是一个对象和一个字符串。该字符串必须是对象的某个属性。如果对象允许,该函数将删除指定的属性。例如 delattr(x, 'foobar') 等价于 del x.foobar 。

  class dict(**kwarg)

  class dict(mapping, **kwarg)

  class dict(iterable, **kwarg)

  创建一个新的字典。dict 对象是一个字典类。参见 dict 和 映射类型 --- dict 了解这个类。

  其他容器类型,请参见内置的 list、set 和 tuple 类,以及 collections 模块。

  应用见:https://www.cnblogs.com/noah0532/p/10923290.html

 

16. dir([object])

  解释:如果没有实参,则返回当前本地作用域中的名称列表。如果有实参,它会尝试返回该对象的有效属性列表。

如果对象有一个名为 __dir__() 的方法,那么该方法将被调用,并且必须返回一个属性列表。这允许实现自定义 __getattr__() 或 __getattribute__() 函数的对象能够自定义 dir() 来报告它们的属性。

  如果对象不提供 __dir__(),这个函数会尝试从对象已定义的 __dict__ 属性和类型对象收集信息。结果列表并不总是完整的,如果对象有自定义 __getattr__(),那结果可能不准确。默认的 dir() 机制对不同类型的对象行为不同,它会试图返回最相关而不是最全的信息:如果对象是模块对象,则列表包含模块的属性名称。

  如果对象是类型或类对象,则列表包含它们的属性名称,并且递归查找所有基类的属性。否则,列表包含对象的属性名称,它的类属性名称,并且递归查找它的类的所有基类的属性。

返回的列表按字母表排序。例如:

import struct

dir()   # show the names in the module namespace  # doctest: +SKIP
# ['__builtins__', '__name__', 'struct']
dir(struct)   # show the names in the struct module # doctest: +SKIP
# ['Struct', '__all__', '__builtins__', '__cached__', '__doc__', '__file__',
# 
#  '__initializing__', '__loader__', '__name__', '__package__',
# 
#  '_clearcache', 'calcsize', 'error', 'pack', 'pack_into',
# 
#  'unpack', 'unpack_from']
class Shape:
    def __dir__(self):
        return ['area', 'perimeter', 'location']
s = Shape()
dir(s)
# ['area', 'location', 'perimeter']

  注解 :因为 dir() 主要是为了便于在交互式时使用,所以它会试图返回人们感兴趣的名字集合,而不是试图保证结果的严格性或一致性,它具体的行为也可能在不同版本之间改变。例如,当实参是一个类时,metaclass 的属性不包含在结果列表中。

 

17. divmod(a, b)

  它将两个(非复数)数字作为实参,并在执行整数除法时返回一对商和余数。对于混合操作数类型,适用双目算术运算符的规则。对于整数,结果和 (a // b, a % b) 一致。对于浮点数,结果是 (q, a % b) ,q 通常是 math.floor(a / b) 但可能会比 1 小。在任何情况下, q * b + a % b 和 a 基本相等;如果 a % b 非零,它的符号和 b 一样,并且 0 <= abs(a % b) < abs(b) 。

   应用:

print(divmod(1,2))
# (0, 1)

 

18. enumerate(iterable, start=0)

  解释:返回一个枚举对象。iterable 必须是一个序列,或 iterator,或其他支持迭代的对象。 enumerate() 返回的迭代器的 __next__() 方法返回一个元组,里面包含一个计数值(从 start 开始,默认为 0)和通过迭代 iterable 获得的值。

  应用:

seasons = ['Spring', 'Summer', 'Fall', 'Winter']
list(enumerate(seasons))
# [(0, 'Spring'), (1, 'Summer'), (2, 'Fall'), (3, 'Winter')]
list(enumerate(seasons, start=1))
# [(1, 'Spring'), (2, 'Summer'), (3, 'Fall'), (4, 'Winter')]
# 等价于:
def enumerate(sequence, start=0):
    n = start
    for elem in sequence:
        yield n, elem
        n += 1

 

19. eval(expression, globals=None, locals=None)

  解释:实参是一个字符串,以及可选的 globals 和 locals。globals 实参必须是一个字典。locals 可以是任何映射对象。

  expression 参数会作为一个 Python 表达式(从技术上说是一个条件列表)被解析并求值,使用 globals 和 locals 字典作为全局和局部命名空间。 如果 globals 字典存在且不包含以 __builtins__ 为键的值,则会在解析 expression 之前插入以此为键的对内置模块 builtins 的字典的引用。 这意味着 expression 通常具有对标准 builtins 模块的完全访问权限且受限的环境会被传播。 如果省略 locals 字典则其默认值为 globals 字典。 如果两个字典同时省略,表达式会在 eval() 被调用的环境中执行。 返回值为表达式求值的结果。 语法错误将作为异常被报告。 例如:

x = 1
print(eval('x+1'))
# 2

  这个函数也可以用来执行任何代码对象(如 compile() 创建的)。这种情况下,参数是代码对象,而不是字符串。如果编译该对象时的 mode 实参是 'exec' 那么 eval() 返回值为 None 。

  提示: exec() 函数支持动态执行语句。 globals() 和 locals() 函数各自返回当前的全局和本地字典,因此您可以将它们传递给 eval() 或 exec() 来使用。

 

20. exec(object[, globals[, locals]])

  解释:这个函数支持动态执行 Python 代码。object 必须是字符串或者代码对象。如果是字符串,那么该字符串将被解析为一系列 Python 语句并执行(除非发生语法错误)。[1] 如果是代码对象,它将被直接执行。在任何情况下,被执行的代码都需要和文件输入一样是有效的(见参考手册中关于文件输入的章节)。请注意即使在传递给 exec() 函数的代码的上下文中,return 和 yield 语句也不能在函数定义之外使用。该函数返回值是 None 。

  无论哪种情况,如果省略了可选参数,代码将在当前范围内执行。如果提供了 globals 参数,就必须是字典类型,而且会被用作全局和本地变量。如果同时提供了 globals 和 locals 参数,它们分别被用作全局和本地变量。如果提供了 locals 参数,则它可以是任何映射型的对象。请记住在模块层级,全局和本地变量是相同的字典。如果 exec 有两个不同的 globals 和 locals 对象,代码就像嵌入在类定义中一样执行。

  如果 globals 字典不包含 __builtins__ 键值,则将为该键插入对内建 builtins 模块字典的引用。因此,在将执行的代码传递给 exec() 之前,可以通过将自己的 __builtins__ 字典插入到 globals 中来控制可以使用哪些内置代码。

  注解 :内置 globals() 和 locals() 函数各自返回当前的全局和本地字典,因此可以将它们传递给 exec() 的第二个和第三个实参。

  注解 :默认情况下,locals 的行为如下面 locals() 函数描述的一样:不要试图改变默认的 locals 字典。如果您想在 exec() 函数返回时知道代码对 locals 的变动,请明确地传递 locals 字典。

  应用:

source = "print('Hello world!')"
>>> c_source = compile(source, '', 'exec')
>>> exec(c_source)
Hello world!

# 'exec'模式多行
>>> x = "i = input('Number you want to show: ')\nprint(i)"
>>> c_x = compile(x, '', 'exec')
>>> exec(c_x)
Number you want to show: 12
12

 

21. filter(function, iterable)

  解释:用 iterable 中函数 function 返回真的那些元素,构建一个新的迭代器。iterable 可以是一个序列,一个支持迭代的容器,或一个迭代器。如果 function 是 None ,则会假设它是一个身份函数,即 iterable 中所有返回假的元素会被移除。

  请注意, filter(function, iterable) 相当于一个生成器表达式,当 function 不是 None 的时候为 (item for item in iterable if function(item));function 是 None 的时候为 (item for item in iterable if item) 。请参阅 itertools.filterfalse() 了解,只有 function 返回 false 时才选取 iterable 中元素的补充函数。

  应用:https://www.cnblogs.com/noah0532/p/10897648.html

 

22. class float([x])

  解释:返回从数字或字符串 x 生成的浮点数。

  如果实参是字符串,则它必须是包含十进制数字的字符串,字符串前面可以有符号,之前也可以有空格。可选的符号有 '+' 和 '-' ; '+' 对创建的值没有影响。实参也可以是 NaN(非数字)、正负无穷大的字符串。确切地说,除去首尾的空格后,输入必须遵循以下语法:

  sign           ::=  "+" | "-"

  infinity       ::=  "Infinity" | "inf"

  nan            ::=  "nan"

  numeric_value  ::=  floatnumber | infinity | nan

  numeric_string ::=  [sign] numeric_value

  这里, floatnumber 是 Python 浮点数的字符串形式,详见 浮点数字面值。字母大小写都可以,例如,“inf”、“Inf”、“INFINITY”、“iNfINity” 都可以表示正无穷大。

  另一方面,如果实参是整数或浮点数,则返回具有相同值(在 Python 浮点精度范围内)的浮点数。如果实参在 Python 浮点精度范围外,则会触发 OverflowError。

  对于一般的 Python 对象 x , float(x) 指派给 x.__float__() 。

  如果没有实参,则返回 0.0 。

  例如:

>>> float('+1.23')
1.23
>>> float('   -12345\n')
-12345.0
>>> float('1e-003')
0.001
>>> float('+1E6')
1000000.0
>>> float('-Infinity')
-inf

  数字类型 --- int, float, complex 描述了浮点类型。

  在 3.6 版更改: 您可以使用下划线将代码文字中的数字进行分组。

  在 3.7 版更改: x 现在只能作为位置参数。

 

23. format(value[, format_spec])

  解释:将 value 转换为 format_spec 控制的“格式化”表示。format_spec 的解释取决于 value 实参的类型,但是大多数内置类型使用标准格式化语法:格式规格迷你语言。默认的 format_spec 是一个空字符串,它通常和调用 str(value) 的结果相同。

  调用 format(value, format_spec) 会转换成 type(value).__format__(value, format_spec) ,所以实例字典中的 __format__() 方法将不会调用。如果搜索到 object 有这个方法但 format_spec 不为空,format_spec 或返回值不是字符串,会触发 TypeError 异常。

  在 3.4 版更改: 当 format_spec 不是空字符串时, object().__format__(format_spec) 会触发 TypeError。

  应用:https://www.cnblogs.com/noah0532/p/8413534.html

 

24. class frozenset([iterable])

  解释:返回一个新的 frozenset 对象,它包含可选参数 iterable 中的元素。 frozenset 是一个内置的类。有关此类的文档,请参阅 frozenset 和 集合类型 --- set, frozenset。

  请参阅内建的 set、list、tuple 和 dict 类,以及 collections 模块来了解其它的容器。

  应用:https://www.cnblogs.com/noah0532/p/8419210.html

 

25. getattr(object, name[, default])

  解释:返回对象命名属性的值。name 必须是字符串。如果该字符串是对象的属性之一,则返回该属性的值。例如, getattr(x, 'foobar') 等同于 x.foobar。如果指定的属性不存在,且提供了 default 值,则返回它,否则触发 AttributeError。

   应用:https://www.cnblogs.com/noah0532/p/10923290.html

 

26. globals()

  解释:返回表示当前全局符号表的字典。这总是当前模块的字典(在函数或方法中,不是调用它的模块,而是定义它的模块)。

   应用:

>>>a='Thomas'
>>> print(globals()) # globals 函数返回一个全局变量的字典,包括所有导入的变量。
{'__builtins__': <module '__builtin__' (built-in)>, '__name__': '__main__', '__doc__': None, 'a': 'runoob', '__package__': None}

 

27. hasattr(object, name)

  解释:该实参是一个对象和一个字符串。如果字符串是对象的属性之一的名称,则返回 True,否则返回 False。(此功能是通过调用 getattr(object, name) 看是否有 AttributeError 异常来实现的。)

  应用:https://www.cnblogs.com/noah0532/p/10923290.html

 

28. hash(object)

  解释:返回该对象的哈希值(如果它有的话)。哈希值是整数。它们在字典查找元素时用来快速比较字典的键。相同大小的数字变量有相同的哈希值(即使它们类型不同,如 1 和 1.0)。

  注解: 如果对象实现了自己的 __hash__() 方法,请注意,hash() 根据机器的字长来截断返回值。另请参阅 __hash__()。

  应用:

>>>hash('test')            # 字符串
2314058222102390712
>>> hash(1)                 # 数字
1
>>> hash(str([1,2,3]))      # 集合
1335416675971793195
>>> hash(str(sorted({'1':1}))) # 字典
7666464346782421378
>>>

 

29. help([object])

  解释:启动内置的帮助系统(此函数主要在交互式中使用)。如果没有实参,解释器控制台里会启动交互式帮助系统。如果实参是一个字符串,则在模块、函数、类、方法、关键字或文档主题中搜索该字符串,并在控制台上打印帮助信息。如果实参是其他任意对象,则会生成该对象的帮助页。

  请注意如果在函数的形参列表中出现了斜杠 (/),则它在发起调用 help() 的时候意味着斜杠之前的均为仅限位置形参。 更多相关信息,请参阅 有关仅限位置形参的 FAQ 条目。

  该函数通过 site 模块加入到内置命名空间。

  在 3.4 版更改: pydoc 和 inspect 的变更使得可调用对象的签名信息更加全面和一致。

   应用:

help("class")
# Class definitions
# *****************
# 
# A class definition defines a class object (see section The standard
# type hierarchy):
# 
#    classdef    ::= [decorators] "class" classname [inheritance] ":" suite
#    inheritance ::= "(" [argument_list] ")"
#    classname   ::= identifier
# 
# A class definition is an executable statement.  The inheritance list
# usually gives a list of base classes (see Metaclasses for more
# advanced uses), so each item in the list should evaluate to a class
# object which allows subclassing.  Classes without an inheritance list
# inherit, by default, from the base class "object"; hence,
# 
#    class Foo:
#        pass
# 
# is equivalent to
# 
#    class Foo(object):
#        pass
# 
# The class’s suite is then executed in a new execution frame (see
# Naming and binding), using a newly created local namespace and the
# original global namespace. (Usually, the suite contains mostly
# function definitions.)  When the class’s suite finishes execution, its
# execution frame is discarded but its local namespace is saved. [3] A
# class object is then created using the inheritance list for the base
# classes and the saved local namespace for the attribute dictionary.
# The class name is bound to this class object in the original local
# namespace.
# 
# The order in which attributes are defined in the class body is
# preserved in the new class’s "__dict__".  Note that this is reliable
# only right after the class is created and only for classes that were
# defined using the definition syntax.
# 
# Class creation can be customized heavily using metaclasses.
# 
# Classes can also be decorated: just like when decorating functions,
# 
#    @f1(arg)
#    @f2
#    class Foo: pass
# 
# is roughly equivalent to
# 
#    class Foo: pass
#    Foo = f1(arg)(f2(Foo))
# 
# The evaluation rules for the decorator expressions are the same as for
# function decorators.  The result is then bound to the class name.
# 
# **Programmer’s note:** Variables defined in the class definition are
# class attributes; they are shared by instances.  Instance attributes
# can be set in a method with "self.name = value".  Both class and
# instance attributes are accessible through the notation “"self.name"”,
# and an instance attribute hides a class attribute with the same name
# when accessed in this way.  Class attributes can be used as defaults
# for instance attributes, but using mutable values there can lead to
# unexpected results.  Descriptors can be used to create instance
# variables with different implementation details.
# 
# See also:
# 
#   **PEP 3115** - Metaclasses in Python 3000
#      The proposal that changed the declaration of metaclasses to the
#      current syntax, and the semantics for how classes with
#      metaclasses are constructed.
# 
#   **PEP 3129** - Class Decorators
#      The proposal that added class decorators.  Function and method
#      decorators were introduced in **PEP 318**.
# 
# Related help topics: CLASSES, SPECIALMETHODS

 

30. hex(x)

  解释:将整数转换为以“0x”为前缀的小写十六进制字符串。如果 x 不是 Python int 对象,则必须定义返回整数的 __index__() 方法。一些例子:

  如果要将整数转换为大写或小写的十六进制字符串,并可选择有无“0x”前缀,则可以使用如下方法:

  应用:略

 

31. id(object)

  解释:返回对象的“标识值”。该值是一个整数,在此对象的生命周期中保证是唯一且恒定的。两个生命期不重叠的对象可能具有相同的 id() 值。

  应用:略

 

32.input([prompt])

  解释:如果存在 prompt 实参,则将其写入标准输出,末尾不带换行符。接下来,该函数从输入中读取一行,将其转换为字符串(除了末尾的换行符)并返回。当读取到 EOF 时,则触发 EOFError。如果加载了 readline 模块,input() 将使用它来提供复杂的行编辑和历史记录功能。

  应用:略

 

33. class int([x])

  解释:class int(x, base=10)

  返回一个使用数字或字符串 x 生成的整数对象,或者没有实参的时候返回 0 。如果 x 定义了 __int__(),int(x) 返回 x.__int__() 。如果 x 定义了 __trunc__(),它返回 x.__trunc__() 。对于浮点数,它向零舍入。

  如果 x 不是数字,或者有 base 参数,x 必须是字符串、bytes、表示进制为 base 的 整数字面值 的 bytearray 实例。该文字前可以有 + 或 - (中间不能有空格),前后可以有空格。一个进制为 n 的数字包含 0 到 n-1 的数,其中 a 到 z (或 A 到 Z )表示 10 到 35。默认的 base 为 10 ,允许的进制有 0、2-36。2、8、16 进制的数字可以在代码中用 0b/0B 、 0o/0O 、 0x/0X 前缀来表示。进制为 0 将安照代码的字面量来精确解释,最后的结果会是 2、8、10、16 进制中的一个。所以 int('010', 0) 是非法的,但 int('010') 和 int('010', 8) 是合法的。

  整数类型定义请参阅 数字类型 --- int, float, complex 。

  在 3.4 版更改: 如果 base 不是 int 的实例,但 base 对象有 base.__index__ 方法,则会调用该方法来获取进制数。以前的版本使用 base.__int__ 而不是 base.__index__。

  在 3.6 版更改: 您可以使用下划线将代码文字中的数字进行分组。

  在 3.7 版更改: x 现在只能作为位置参数。

  应用:略

 

34. isinstance(object, classinfo)

  解释:如果 object 实参是 classinfo 实参的实例,或者是(直接、间接或 虚拟)子类的实例,则返回 true。如果 object 不是给定类型的对象,函数始终返回 false。如果 classinfo 是对象类型(或多个递归元组)的元组,如果 object 是其中的任何一个的实例则返回 true。 如果 classinfo 既不是类型,也不是类型元组或类型的递归元组,那么会触发 TypeError 异常。

  应用:

  https://www.cnblogs.com/noah0532/p/8429899.html

  https://www.cnblogs.com/noah0532/p/8429901.html

  https://www.cnblogs.com/noah0532/p/8418278.html

 

35. issubclass(class, classinfo)

  如果 class 是 classinfo 的子类(直接、间接或 虚拟 的),则返回 true。classinfo 可以是类对象的元组,此时 classinfo 中的每个元素都会被检查。其他情况,会触发 TypeError 异常。

  应用:略

 

36. iter(object[, sentinel])

  解释:返回一个 iterator 对象。根据是否存在第二个实参,第一个实参的解释是非常不同的。如果没有第二个实参,object 必须是支持迭代协议(有 __iter__() 方法)的集合对象,或必须支持序列协议(有 __getitem__() 方法,且数字参数从 0 开始)。如果它不支持这些协议,会触发 TypeError。如果有第二个实参 sentinel,那么 object 必须是可调用的对象。这种情况下生成的迭代器,每次迭代调用它的 __next__() 方法时都会不带实参地调用 object;如果返回的结果是 sentinel 则触发 StopIteration,否则返回调用结果。

  另请参阅 迭代器类型。

  适合 iter() 的第二种形式的应用之一是构建块读取器。 例如,从二进制数据库文件中读取固定宽度的块,直至到达文件的末尾:

  应用:

from functools import partial

with open('mydata.db', 'rb') as f:

    for block in iter(partial(f.read, 64), b''):

        process_block(block)

 

37.len(s)

  解释:返回对象的长度(元素个数)。实参可以是序列(如 string、bytes、tuple、list 或 range 等)或集合(如 dictionary、set 或 frozen set 等)。

   应用:略

 

38. class list([iterable])

  解释:除了是函数,list 也是可变序列类型,详情请参阅 列表 和 序列类型 --- list, tuple, range。

     应用:略

 

39. locals()

  解释:更新并返回表示当前本地符号表的字典。 在函数代码块但不是类代码块中调用 locals() 时将返回自由变量。 请注意在模块层级上,locals() 和 globals() 是同一个字典。

  注解:不要更改此字典的内容;更改不会影响解释器使用的局部变量或自由变量的值。

  应用:略

 

40. map(function, iterable, ...)

  产生一个将 function 应用于迭代器中所有元素并返回结果的迭代器。如果传递了额外的 iterable 实参,function 必须接受相同个数的实参,并使用所有迭代器中并行获取的元素。当有多个迭代器时,最短的迭代器耗尽则整个迭代结束。如果函数的输入已经是元组实参,请参阅 itertools.starmap()。

  应用:https://www.cnblogs.com/noah0532/p/10897642.html

 

41. max(iterable, *[, key, default])

  解释:max(arg1, arg2, *args[, key])

  返回可迭代对象中最大的元素,或者返回两个及以上实参中最大的。

  如果只提供了一个位置参数,它必须是非空 iterable,返回可迭代对象中最大的元素;如果提供了两个及以上的位置参数,则返回最大的位置参数。

  有两个可选只能用关键字的实参。key 实参指定排序函数用的参数,如传给 list.sort() 的。default 实参是当可迭代对象为空时返回的值。如果可迭代对象为空,并且没有给 default ,则会触发 ValueError。

  如果有多个最大元素,则此函数将返回第一个找到的。这和其他稳定排序工具如 sorted(iterable, key=keyfunc, reverse=True)[0] 和 heapq.nlargest(1, iterable, key=keyfunc) 保持一致。

  3.4 新版功能: keyword-only 实参 default 。

  应用:略

 

42. memoryview(obj)

  解释:返回由给定实参创建的“内存视图”对象。有关详细信息,请参阅 内存视图。

  应用:略

 

43. min(iterable, *[, key, default])

  解释:min(arg1, arg2, *args[, key])

  返回可迭代对象中最小的元素,或者返回两个及以上实参中最小的。

  如果只提供了一个位置参数,它必须是 iterable,返回可迭代对象中最小的元素;如果提供了两个及以上的位置参数,则返回最小的位置参数。

  有两个可选只能用关键字的实参。key 实参指定排序函数用的参数,如传给 list.sort() 的。default 实参是当可迭代对象为空时返回的值。如果可迭代对象为空,并且没有给 default ,则会触发 ValueError。

  如果有多个最小元素,则此函数将返回第一个找到的。这和其他稳定排序工具如 sorted(iterable, key=keyfunc)[0] 和 heapq.nsmallest(1, iterable, key=keyfunc) 保持一致。

  应用:略

 

44. next(iterator[, default])

  解释:通过调用 iterator 的 __next__() 方法获取下一个元素。如果迭代器耗尽,则返回给定的 default,如果没有默认值则触发 StopIteration。

  class object

  返回一个没有特征的新对象。object 是所有类的基类。它具有所有 Python 类实例的通用方法。这个函数不接受任何实参。

  注解 由于 object 没有 __dict__,因此无法将任意属性赋给 object 的实例。

  应用:略

 

45. oct(x)

  解释:将一个整数转变为一个前缀为“0o”的八进制字符串。结果是一个合法的 Python 表达式。如果 x 不是 Python 的 int 对象,那它需要定义 __index__() 方法返回一个整数。一些例子:

>>> oct(8)
'0o10'
>>> oct(-56)
'-0o70'

  如果要将整数转换为八进制字符串,并可选择有无“0o”前缀,则可以使用如下方法:

>>> '%#o' % 10, '%o' % 10
('0o12', '12')
>>> format(10, '#o'), format(10, 'o')
('0o12', '12')
>>> f'{10:#o}', f'{10:o}'
('0o12', '12')

  另见 format() 获取更多信息。

 

46. open(file, mode='r', buffering=-1, encoding=None, errors=None, newline=None, closefd=True, opener=None)

  解释:打开 file 并返回对应的 file object。如果该文件不能打开,则触发 OSError。

  file 是一个 path-like object,表示将要打开的文件的路径(绝对路径或者当前工作目录的相对路径),也可以是要被封装的整数类型文件描述符。(如果是文件描述符,它会随着返回的 I/O 对象关闭而关闭,除非 closefd 被设为 False 。)

  mode 是一个可选字符串,用于指定打开文件的模式。默认值是 'r' ,这意味着它以文本模式打开并读取。其他常见模式有:写入 'w' (截断已经存在的文件);排它性创建 'x' ;追加写 'a' (在 一些 Unix 系统上,无论当前的文件指针在什么位置,所有 写入都会追加到文件末尾)。在文本模式,如果 encoding 没有指定,则根据平台来决定使用的编码:使用 locale.getpreferredencoding(False) 来获取本地编码。(要读取和写入原始字节,请使用二进制模式并不要指定 encoding。)可用的模式有:

字符意义

  'r'读取(默认)

  'w'写入,并先截断文件

  'x'排它性创建,如果文件已存在则失败

  'a'写入,如果文件存在则在末尾追加

  'b'二进制模式

  't'文本模式(默认)

  '+'更新磁盘文件(读取并写入)

  默认的模式是 'r' (打开并读取文本,同 'rt' )。对于二进制写入, 'w+b' 模式打开并把文件截断成 0 字节; 'r+b' 则不会截断。

  正如在 概述 中提到的,Python区分二进制和文本I/O。以二进制模式打开的文件(包括 mode 参数中的 'b' )返回的内容为 bytes`对象,不进行任何解码。在文本模式下(默认情况下,或者在 *mode* 参数中包含 `'t'` )时,文件内容返回为 str ,首先使用指定的 encoding (如果给定)或者使用平台默认的的字节编码解码。

  此外还允许使用一个模式字符 'U',该字符已不再具有任何效果,并被视为已弃用。 之前它会在文本模式中启用 universal newlines,这在 Python 3.0 中成为默认行为。 请参阅 newline 形参的文档了解更多细节。

  注解 Python不依赖于底层操作系统的文本文件概念;所有处理都由Python本身完成,因此与平台无关。

  buffering 是一个可选的整数,用于设置缓冲策略。传递0以切换缓冲关闭(仅允许在二进制模式下),1选择行缓冲(仅在文本模式下可用),并且>1的整数以指示固定大小的块缓冲区的大小(以字节为单位)。如果没有给出 buffering 参数,则默认缓冲策略的工作方式如下:

  二进制文件以固定大小的块进行缓冲;使用启发式方法选择缓冲区的大小,尝试确定底层设备的“块大小”或使用 io.DEFAULT_BUFFER_SIZE。在许多系统上,缓冲区的长度通常为4096或8192字节。

  “交互式”文本文件( isatty() 返回 True 的文件)使用行缓冲。其他文本文件使用上述策略用于二进制文件。

  encoding 是用于解码或编码文件的编码的名称。这应该只在文本模式下使用。默认编码是依赖于平台的(不 管 locale.getpreferredencoding() 返回何值),但可以使用任何Python支持的 text encoding 。有关支持的编码列表,请参阅 codecs 模块。

  errors 是一个可选的字符串参数,用于指定如何处理编码和解码错误 - 这不能在二进制模式下使用。可以使用各种标准错误处理程序(列在 Error Handlers ),但是使用 codecs.register_error() 注册的任何错误处理名称也是有效的。标准名称包括:

  如果存在编码错误,'strict' 会引发 ValueError 异常。 默认值 None 具有相同的效果。

  'ignore' 忽略错误。请注意,忽略编码错误可能会导致数据丢失。

  'replace' 会将替换标记(例如 '?' )插入有错误数据的地方。

  'surrogateescape' 将表示任何不正确的字节作为Unicode专用区中的代码点,范围从U+DC80到U+DCFF。当在写入数据时使用 surrogateescape 错误处理程序时,这些私有代码点将被转回到相同的字节中。这对于处理未知编码的文件很有用。

  只有在写入文件时才支持 'xmlcharrefreplace'。编码不支持的字符将替换为相应的XML字符引用 &#nnn;。

  'backslashreplace' 用Python的反向转义序列替换格式错误的数据。

  'namereplace' (也只在编写时支持)用 \N{...} 转义序列替换不支持的字符。

  newline 控制 universal newlines 模式如何生效(它仅适用于文本模式)。它可以是 None,'','\n','\r' 和 '\r\n'。它的工作原理:

  从流中读取输入时,如果 newline 为 None,则启用通用换行模式。输入中的行可以以 '\n','\r' 或 '\r\n' 结尾,这些行被翻译成 '\n' 在返回呼叫者之前。如果它是 '',则启用通用换行模式,但行结尾将返回给调用者未翻译。如果它具有任何其他合法值,则输入行仅由给定字符串终止,并且行结尾将返回给未调用的调用者。

  将输出写入流时,如果 newline 为 None,则写入的任何 '\n' 字符都将转换为系统默认行分隔符 os.linesep。如果 newline 是 '' 或 '\n',则不进行翻译。如果 newline 是任何其他合法值,则写入的任何 '\n' 字符将被转换为给定的字符串。

  如果 closefd 是 False 并且给出了文件描述符而不是文件名,那么当文件关闭时,底层文件描述符将保持打开状态。如果给出文件名则 closefd 必须为 True (默认值),否则将引发错误。

  可以通过传递可调用的 opener 来使用自定义开启器。然后通过使用参数( file,flags )调用 opener 获得文件对象的基础文件描述符。 opener 必须返回一个打开的文件描述符(使用 os.open as opener 时与传递 None 的效果相同)。

新创建的文件是 不可继承的。

  下面的示例使用 os.open() 函数的 dir_fd 的形参,从给定的目录中用相对路径打开文件:

>>> import os
>>> dir_fd = os.open('somedir', os.O_RDONLY)
>>> def opener(path, flags):
...     return os.open(path, flags, dir_fd=dir_fd)
...
>>> with open('spamspam.txt', 'w', opener=opener) as f:
...     print('This will be written to somedir/spamspam.txt', file=f)
...
>>> os.close(dir_fd)  # don't leak a file descriptor

  open() 函数所返回的 file object 类型取决于所用模式。 当使用 open() 以文本模式 ('w', 'r', 'wt', 'rt' 等) 打开文件时,它将返回 io.TextIOBase (特别是 io.TextIOWrapper) 的一个子类。 当使用缓冲以二进制模式打开文件时,返回的类是 io.BufferedIOBase 的一个子类。 具体的类会有多种:在只读的二进制模式下,它将返回 io.BufferedReader;在写入二进制和追加二进制模式下,它将返回 io.BufferedWriter,而在读/写模式下,它将返回 io.BufferedRandom。 当禁用缓冲时,则会返回原始流,即 io.RawIOBase 的一个子类 io.FileIO。

  另请参阅文件操作模块,例如 fileinput、io (声明了 open())、os、os.path、tempfile 和 shutil。

  在 3.3 版更改:

  增加了 opener 形参。

  增加了 'x' 模式。

  过去触发的 IOError,现在是 OSError 的别名。

  如果文件已存在但使用了排它性创建模式( 'x' ),现在会触发 FileExistsError。

  在 3.4 版更改:

  文件现在禁止继承。

  Deprecated since version 3.4, will be removed in version 4.0: 'U' 模式。

  在 3.5 版更改:

  如果系统调用被中断,但信号处理程序没有触发异常,此函数现在会重试系统调用,而不是触发 InterruptedError 异常(原因详见 PEP 475)。

  增加了 'namereplace' 错误处理接口。

  在 3.6 版更改:

  增加对实现了 os.PathLike 对象的支持。

  在 Windows 上,打开一个控制台缓冲区将返回 io.RawIOBase 的子类,而不是 io.FileIO。

   其他应用详见文件的操作:https://www.cnblogs.com/noah0532/p/8437997.html

 

47. ord(c)

  解释:对表示单个 Unicode 字符的字符串,返回代表它 Unicode 码点的整数。例如 ord('a') 返回整数 97, ord('€') (欧元符合)返回 8364 。这是 chr() 的逆函数。

   应用:略

 

48. pow(x, y[, z])

  解释:返回 x 的 y 次幂;如果 z 存在,则对 z 取余(比直接 pow(x, y) % z 计算更高效)。两个参数形式的 pow(x, y) 等价于幂运算符: x**y。

  参数必须为数值类型。 对于混用的操作数类型,则适用二元算术运算符的类型强制转换规则。 对于 int 操作数,结果具有与操作数相同的类型(转换后),除非第二个参数为负值;在这种情况下,所有参数将被转换为浮点数并输出浮点数结果。 例如,10**2 返回 100,但 10**-2 返回 0.01。 如果第二个参数为负值,则第三个参数必须省略。 如果存在 z,则 x 和 y 必须为整数类型,且 y 必须为非负数。

  应用:略

 

49. print(*objects, sep=' ', end='\n', file=sys.stdout, flush=False)

  解释:将 objects 打印到 file 指定的文本流,以 sep 分隔并在末尾加上 end。 sep, end, file 和 flush 如果存在,它们必须以关键字参数的形式给出。

  所有非关键字参数都会被转换为字符串,就像是执行了 str() 一样,并会被写入到流,以 sep 且在末尾加上 end。 sep 和 end 都必须为字符串;它们也可以为 None,这意味着使用默认值。 如果没有给出 objects,则 print() 将只写入 end。

  file 参数必须是一个具有 write(string) 方法的对象;如果参数不存在或为 None,则将使用 sys.stdout。 由于要打印的参数会被转换为文本字符串,因此 print() 不能用于二进制模式的文件对象。 对于这些对象,应改用 file.write(...)。

  输出是否被缓存通常决定于 file,但如果 flush 关键字参数为真值,流会被强制刷新。

  在 3.3 版更改: 增加了 flush 关键字参数。

  应用:https://www.cnblogs.com/noah0532/p/8413534.html

 

50. class property(fget=None, fset=None, fdel=None, doc=None)

  解释:返回 property 属性。

  fget 是获取属性值的函数。 fset 是用于设置属性值的函数。 fdel 是用于删除属性值的函数。并且 doc 为属性对象创建文档字符串。

  一个典型的用法是定义一个托管属性 x:

class C:

    def __init__(self):

        self._x = None

    def getx(self):

        return self._x


    def setx(self, value):

        self._x = value

    def delx(self):

        del self._x

    x = property(getx, setx, delx, "I'm the 'x' property.")

  如果 c 是 C 的实例,c.x 将调用getter,c.x = value 将调用setter, del c.x 将调用deleter。

  如果给出,doc 将成为该 property 属性的文档字符串。 否则该 property 将拷贝 fget 的文档字符串(如果存在)。 这令使用 property() 作为 decorator 来创建只读的特征属性可以很容易地实现:

class Parrot:

    def __init__(self):

        self._voltage = 100000

    @property

    def voltage(self):

        """Get the current voltage."""

        return self._voltage

以上 @property 装饰器会将 voltage() 方法转化为一个具有相同名称的只读属性的 "getter",并将 voltage 的文档字符串设置为 "Get the current voltage."

特征属性对象具有 getter, setter 以及 deleter 方法,它们可用作装饰器来创建该特征属性的副本,并将相应的访问函数设为所装饰的函数。 这最好是用一个例子来解释:

class C:

    def __init__(self):

        self._x = None

 

    @property

    def x(self):

        """I'm the 'x' property."""

        return self._x


    @x.setter

    def x(self, value):

        self._x = value


    @x.deleter

    def x(self):

        del self._x

  上述代码与第一个例子完全等价。 注意一定要给附加函数与原始的特征属性相同的名称 (在本例中为 x。)

  返回的特征属性对象同样具有与构造器参数相对应的属性 fget, fset 和 fdel。

  在 3.5 版更改: 特性属性对象的文档字符串现在是可写的。

  其他应用:https://www.cnblogs.com/noah0532/p/10926966.html

 

51. range(stop)

  解释:range(start, stop[, step])

  虽然被称为函数,但 range 实际上是一个不可变的序列类型,参见在 range 对象 与 序列类型 --- list, tuple, range 中的文档说明。

 

52. repr(object)

  解释:返回包含一个对象的可打印表示形式的字符串。 对于许多类型来说,该函数会尝试返回的字符串将会与该对象被传递给 eval() 时所生成的对象具有相同的值,在其他情况下表示形式会是一个括在尖括号中的字符串,其中包含对象类型的名称与通常包括对象名称和地址的附加信息。 类可以通过定义 __repr__() 方法来控制此函数为它的实例所返回的内容。

 

53. reversed(seq)

  解释:返回一个反向的 iterator。 seq 必须是一个具有 __reversed__() 方法的对象或者是支持该序列协议(具有从``0`` 开始的整数类型参数的 __len__() 方法和 __getitem__() 方法)。

  应用:

# 字符串
seqString = 'Runoob'
print(list(reversed(seqString)))
 
# 元组
seqTuple = ('R', 'u', 'n', 'o', 'o', 'b')
print(list(reversed(seqTuple)))
 
# range
seqRange = range(5, 9)
print(list(reversed(seqRange)))
 
# 列表
seqList = [1, 2, 4, 3, 5]
print(list(reversed(seqList)))

 

54. round(number[, ndigits])

  解释:返回 number 舍入到小数点后 ndigits 位精度的值。 如果 ndigits 被省略或为 None,则返回最接近输入值的整数。

  对于支持 round() 的内置类型,值会被舍入到最接近的 10 的负 ndigits 次幂的倍数;如果与两个倍数的距离相等,则选择偶数 (因此,round(0.5) 和 round(-0.5) 均为 0 而 round(1.5) 为 2)。 任何整数值都可作为有效的 ndigits (正数、零或负数)。 如果 ndigits 被省略或为 None 则返回值将为整数。 否则返回值与 number 的类型相同。

  对于一般的 Python 对象 number, round 将委托给 number.__round__。

  注解 对浮点数执行 round() 的行为可能会令人惊讶:例如,round(2.675, 2) 将给出 2.67 而不是期望的 2.68。 这不算是程序错误:这一结果是由于大多数十进制小数实际上都不能以浮点数精确地表示。 请参阅 浮点算术:争议和限制 了解更多信息。

  应用:略

 

55. class set([iterable])

  解释:返回一个新的 set 对象,可以选择带有从 iterable 获取的元素。 set 是一个内置类型。 请查看 set 和 集合类型 --- set, frozenset 获取关于这个类的文档。

有关其他容器请参看内置的 frozenset, list, tuple 和 dict 类,以及 collections 模块。

  应用:略

 

56. setattr(object, name, value)

  解释:此函数与 getattr() 两相对应。 其参数为一个对象、一个字符串和一个任意值。 字符串指定一个现有属性或者新增属性。 函数会将值赋给该属性,只要对象允许这种操作。 例如,setattr(x, 'foobar', 123) 等价于 x.foobar = 123。

   应用:https://www.cnblogs.com/noah0532/p/10926966.html

 

57. class slice(stop)

  解释:class slice(start, stop[, step])

  返回一个表示由 range(start, stop, step) 所指定索引集的 slice 对象。 其中 start 和 step 参数默认为 None。 切片对象具有仅会返回对应参数值(或其默认值)的只读数据属性 start, stop 和 step。 它们没有其他的显式功能;不过它们会被 NumPy 以及其他第三方扩展所使用。 切片对象也会在使用扩展索引语法时被生成。 例如: a[start:stop:step] 或 a[start:stop, i]。 请参阅 itertools.islice() 了解返回迭代器的一种替代版本。

   应用:

>>>myslice = slice(5)    # 设置截取5个元素的切片
>>> myslice
slice(None, 5, None)
>>> arr = range(10)
>>> arr
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
>>> arr[myslice]         # 截取 5 个元素
[0, 1, 2, 3, 4]
>>>

 

58. sorted(iterable, *, key=None, reverse=False)

  解释:根据 iterable 中的项返回一个新的已排序列表。具有两个可选参数,它们都必须指定为关键字参数。

  key 指定带有单个参数的函数,用于从 iterable 的每个元素中提取用于比较的键 (例如 key=str.lower)。 默认值为 None (直接比较元素)。

  reverse 为一个布尔值。 如果设为 True,则每个列表元素将按反向顺序比较进行排序。

  使用 functools.cmp_to_key() 可将老式的 cmp 函数转换为 key 函数。

  内置的 sorted() 确保是稳定的。 如果一个排序确保不会改变比较结果相等的元素的相对顺序就称其为稳定的 --- 这有利于进行多重排序(例如先按部门、再按薪级排序)。

  应用:略

 

59. @staticmethod

  解释:将方法转换为静态方法。静态方法不会接收隐式的第一个参数。要声明一个静态方法,请使用此语法

  class C:

    @staticmethod

    def f(arg1, arg2, ...): ...

  @staticmethod 这样的形式称为函数的 decorator -- 详情参阅 函数定义。

  静态方法的调用可以在类上进行 (例如 C.f()) 也可以在实例上进行 (例如 C().f())。

  Python中的静态方法与Java或C ++中的静态方法类似。另请参阅 classmethod() ,用于创建备用类构造函数的变体。

  像所有装饰器一样,也可以像常规函数一样调用 staticmethod ,并对其结果执行某些操作。比如某些情况下需要从类主体引用函数并且您希望避免自动转换为实例方法。对于这些情况,请使用此语法:

  class C:

      builtin_open = staticmethod(open)

  应用:https://www.cnblogs.com/noah0532/p/10926966.html

 

60. class str(object='')

  解释:class str(object=b'', encoding='utf-8', errors='strict')

  返回一个 str 版本的 object 。有关详细信息,请参阅 str() 。

  str 是内置字符串 class 。更多关于字符串的信息查看 文本序列类型 --- str。

  应用:略

 

61. sum(iterable[, start])

  解释:从 start 开始自左向右对 iterable 中的项求和并返回总计值。 start 默认为 0。 iterable 的项通常为数字,开始值则不允许为字符串。

  对某些用例来说,存在 sum() 的更好替代。 拼接字符串序列的更好更快方式是调用 ''.join(sequence)。 要以扩展精度对浮点值求和,请参阅 math.fsum()。 要拼接一系列可迭代对象,请考虑使用 itertools.chain()。

   应用:略

 

62. super([type[, object-or-type]])

  解释:返回一个代理对象,它会将方法调用委托给 type 指定的父类或兄弟类。 这对于访问已在类中被重载的继承方法很有用。 搜索顺序与 getattr() 所使用的相同,只是 type 指定的类型本身会被跳过。

  type 的 __mro__ 属性列出了 getattr() 和 super() 所使用的方法解析顺序。 该属性是动态的,可以在继承层级结构更新的时候任意改变。

  如果省略第二个参数,则返回的超类对象是未绑定的。 如果第二个参数为一个对象,则 isinstance(obj, type) 必须为真值。 如果第二个参数为一个类型,则 issubclass(type2, type) 必须为真值(这适用于类方法)。

  super 有两个典型用例。 在具有单继承的类层级结构中,super 可用来引用父类而不必显式地指定它们的名称,从而令代码更易维护。 这种用法与其他编程语言中 super 的用法非常相似。

  第二个用例是在动态执行环境中支持协作多重继承。 此用例为 Python 所独有,在静态编译语言或仅支持单继承的语言中是不存在的。 这使得实现“菱形图”成为可能,在这时会有多个基类实现相同的方法。 好的设计强制要求这种方法在每个情况下具有相同的调用签名(因为调用顺序是在运行时确定的,也因为该顺序要适应类层级结构的更改,还因为该顺序可能包含在运行时之前未知的兄弟类)。

  对于以上两个用例,典型的超类调用看起来是这样的:

  class C(B):

      def method(self, arg):

          super().method(arg)    # This does the same thing as:

                                 # super(C, self).method(arg)

  请注意 super() 是作为显式加点属性查找的绑定过程的一部分来实现的,例如 super().__getitem__(name)。 它做到这一点是通过实现自己的 __getattribute__() 方法,这样就能以可预测的顺序搜索类,并且支持协作多重继承。 对应地,super() 在像 super()[name] 这样使用语句或操作符进行隐式查找时则未被定义。

  还要注意的是,除了零个参数的形式以外,super() 并不限于在方法内部傅和。 两个参数的形式明确指定参数并进行相应的引用。 零个参数的形式仅适用于类定义内部,因为编译器需要填入必要的细节以正确地检索到被定义的类,还需要为普通访问当前实例。

  应用:https://www.cnblogs.com/noah0532/p/10858320.html

 

63. tuple([iterable])

  解释:虽然被称为函数,但 tuple 实际上是一个不可变的序列类型,参见在 元组 与 序列类型 --- list, tuple, range 中的文档说明。

   应用:略

 

64. class type(object)

  解释:class type(name, bases, dict)

  传入一个参数时,返回 object 的类型。 返回值是一个 type 对象,通常与 object.__class__ 所返回的对象相同。

  推荐使用 isinstance() 内置函数来检测对象的类型,因为它会考虑子类的情况。

  传入三个参数时,返回一个新的 type 对象。 这在本质上是 class 语句的一种动态形式。 name 字符串即类名并且会成为 __name__ 属性;bases 元组列出基类并且会成为 __bases__ 属性;而 dict 字典为包含类主体定义的命名空间并且会被复制到一个标准字典成为 __dict__ 属性。 例如,下面两条语句会创建相同的 type 对象:

>>> class X:
...     a = 1
..
>>> X = type('X', (object,), dict(a=1))

  在 3.6 版更改: type 的子类如果未重载 type.__new__,将不再能使用一个参数的形式来获取对象的类型。

 

65. vars([object])

  解释:返回模块、类、实例或任何其它具有 __dict__ 属性的对象的 __dict__ 属性。

  模块和实例这样的对象具有可更新的 __dict__ 属性;但是,其它对象的 __dict__ 属性可能会设为限制写入(例如,类会使用 types.MappingProxyType 来防止直接更新字典)。

  不带参数时,vars() 的行为类似 locals()。 请注意,locals 字典仅对于读取起作用,因为对 locals 字典的更新会被忽略。

 

>>>print(vars())
{'__builtins__': <module '__builtin__' (built-in)>, '__name__': '__main__', '__doc__': None, '__package__': None}
>>> class Runoob:
...     a = 1
... 
>>> print(vars(Runoob))
{'a': 1, '__module__': '__main__', '__doc__': None}
>>> runoob = Runoob()
>>> print(vars(runoob))
{}

 

66. zip(*iterables)

  解释:创建一个聚合了来自每个可迭代对象中的元素的迭代器。

  返回一个元组的迭代器,其中的第 i 个元组包含来自每个参数序列或可迭代对象的第 i 个元素。 当所输入可迭代对象中最短的一个被耗尽时,迭代器将停止迭代。   当只有一个可迭代对象参数时,它将返回一个单元组的迭代器。 不带参数时,它将返回一个空迭代器。 相当于:

def zip(*iterables):
    # zip('ABCD', 'xy') --> Ax By
    sentinel = object()
    iterators = [iter(it) for it in iterables]
    while iterators:
        result = []
        for it in iterators:
            elem = next(it, sentinel)
            if elem is sentinel:
                return
            result.append(elem)
        yield tuple(result)

  函数会保证可迭代对象按从左至右的顺序被求值。 使得可以通过 zip(*[iter(s)]*n) 这样的惯用形式将一系列数据聚类为长度为 n 的分组。 这将重复 同样的 迭代器 n 次,以便每个输出的元组具有第 n 次调用该迭代器的结果。 它的作用效果就是将输入拆分为长度为 n 的数据块。

  当你不用关心较长可迭代对象末尾不匹配的值时,则 zip() 只须使用长度不相等的输入即可。 如果那些值很重要,则应改用 itertools.zip_longest()。

zip() 与 * 运算符相结合可以用来拆解一个列表:

>>> x = [1, 2, 3]
>>> y = [4, 5, 6]
>>> zipped = zip(x, y)
>>> list(zipped)
[(1, 4), (2, 5), (3, 6)]
>>> x2, y2 = zip(*zip(x, y))
>>> x == list(x2) and y == list(y2)
True

 

67. __import__(name, globals=None, locals=None, fromlist=(), level=0)

  注解 与 importlib.import_module() 不同,这是一个日常 Python 编程中不需要用到的高级函数。

  此函数会由 import 语句发起调用。 它可以被替换 (通过导入 builtins 模块并赋值给 builtins.__import__) 以便修改 import 语句的语义,但是 强烈 不建议这样做,因为使用导入钩子 (参见 PEP 302) 通常更容易实现同样的目标,并且不会导致代码问题,因为许多代码都会假定所用的是默认实现。 同样也不建议直接使用 __import__() 而应该用 importlib.import_module()。

  该函数会导入 name 模块,有可能使用给定的 globals 和 locals 来确定如何在包的上下文中解读名称。 fromlist 给出了应该从由 name 指定的模块导入对象或子模块的名称。 标准实现完全不使用其 locals 参数,而仅使用 globals 参数来确定 import 语句的包上下文。

  level 指定是使用绝对还是相对导入。 0 (默认值) 意味着仅执行绝对导入。 level 为正数值表示相对于模块调用 __import__() 的目录,将要搜索的父目录层数 (详情参见 PEP 328)。

  当 name 变量的形式为 package.module 时,通常将会返回最高层级的包(第一个点号之前的名称),而 不是 以 name 命名的模块。 但是,当给出了非空的 fromlist 参数时,则将返回以 name 命名的模块。

  例如,语句 import spam 的结果将为与以下代码作用相同的字节码:

  spam = __import__('spam', globals(), locals(), [], 0)

语句 import spam.ham 的结果将为以下调用:

  spam = __import__('spam.ham', globals(), locals(), [], 0)

  请注意在这里 __import__() 是如何返回顶层模块的,因为这是通过 import 语句被绑定到特定名称的对象。

  另一方面,语句 from spam.ham import eggs, sausage as saus 的结果将为

  _temp = __import__('spam.ham', globals(), locals(), ['eggs', 'sausage'], 0)
  eggs = _temp.eggs
  saus = _temp.sausage

  在这里, spam.ham 模块会由 __import__() 返回。 要导入的对象将从此对象中提取并赋值给它们对应的名称。

  如果您只想按名称导入模块(可能在包中),请使用 importlib.import_module()

  在 3.3 版更改: Negative values for level are no longer supported (which also changes the default value to 0).

  官方文档连接:https://docs.python.org/zh-cn/3/library/functions.html

 

转载于:https://www.cnblogs.com/noah0532/p/10928722.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值