zoukankan      html  css  js  c++  java
  • python中模块的__all__属性

    python模块中的__all__属性,可用于模块导入时限制,如:
    from module import *
    此时被导入模块若定义了__all__属性,则只有__all__内指定的属性、方法、类可被导入。

    若没定义,则导入模块内的所有公有属性,方法和类 。

    #kk.py
    __all__=('A','func') #在别的模块中,导入该模块时,只能导入__all__中的变量,方法和类
    class A():
        def __init__(self,name,age):
            self.name=name
            self.age=age
     
    class B():
        def __init__(self,name,id):
            self.name=name
            self.id=id
     
    def func():
        print 'func() is called!'
    def func1():
        print 'func1() is called!'
    #test_kk.py
    from kk import *  #kk.py中定义了__all__属性,只能导入__all__中定义的属性,方法和类
    a=A('python','24')
    print a.name,a.age
    func()
    #func1() #NameError: name 'func1' is not defined
    #b=B('python',123456) #NameError: name 'B' is not defined

    运行结果:

    python 24
    func() is called!

    如果一个模块需要暴露的接口改动频繁,__all__ 可以这样定义:
    __all__ = [
        "foo",
        "bar",
        "egg",
    ]
    最后多出来的逗号在 Python 中是允许的,也是符合 PEP8 风格的。
    模块中不使用__all__属性,则导入模块内的所有公有属性,方法和类 。

    模块中使用__all__属性,则表示只导入__all__中指定的属性,因此,使用__all__可以隐藏不想被import的默认值。

    __all__变量是一个由string元素组成的list变量。
    它定义了当我们使用 from <module> import * 导入某个模块的时候能导出的符号(这里代表变量,函数,类等)。
    from <module> import * 默认的行为是从给定的命名空间导出所有的符号(当然下划线开头的变量,方法和类除外)。
    需要注意的是 __all__ 只影响到了 from <module> import * 这种导入方式,
    对于 from <module> import <member> 导入方式并没有影响,仍然可以从外部导入。

  • 相关阅读:
    linux下的内存映射函数mmap详解及示例代码
    Android平台上使用属性系统(property system)
    Android筆記
    Android Prelink
    DataGridView BindingSource BindNavigator
    可排序的ListView
    开源2D绘图组件ZedGraph
    BackgroundWorker示例
    级联datagridview 利用datarelation和bindingsource
    继承DataGridView
  • 原文地址:https://www.cnblogs.com/langqi250/p/9899909.html
Copyright © 2011-2022 走看看