首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

为什么module.__file__返回None?

module.file返回None的原因可能有以下几种情况:

  1. 动态创建的模块:当一个模块是在运行时动态创建的,而不是从文件中导入的时候,module.file会返回None。这是因为动态创建的模块没有对应的文件路径。
  2. 内置模块:内置模块是Python解释器自带的模块,它们通常是用C语言编写的,没有对应的Python源代码文件。因此,当访问内置模块的module.file属性时,会返回None。
  3. 扩展模块:扩展模块是使用其他语言编写的模块,通过Python的扩展机制加载到解释器中。这些模块通常也没有对应的Python源代码文件,因此module.file返回None。
  4. 模块未被导入:如果一个模块在当前的Python解释器会话中没有被导入过,那么module.file会返回None。只有当模块被成功导入后,才能通过module.file获取到模块的文件路径。

总结起来,module.file返回None的情况主要是因为模块是动态创建的、内置模块、扩展模块或者模块未被导入。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

字符设备驱动程序接口

__init__宏:被修饰的函数会被链接器链接放入.init.text段中(本来默认情况下函数是被放入.text段中)。对内核而言是一种暗示,表示该函数仅在初始化期间使用,内核启动时统一会加载.init.text段中的这些模块安装函数,加载完后就会把这个段给释放掉以节省内存。 __exit__宏:被修饰的函数仅用于模块卸载,链接器会将其放入特殊的ELF段。如果模块被直接内嵌到内核中,或内核的配置不允许卸载模块,则被修饰的函数将被简单的丢弃。 prink函数:模块在被加载到内核后,它能调用的函数仅仅是由内核导出的那些函数。KERN_INFO是printk的打印级别,其实只是一个字符串(如<1>)。操作系统的命令行中也会有一个打印级别的设置(值为0-7),当前操作系统中执行printk的时候会去对比printk中的打印级别和操作系统命令行中设置的打印级别,小于命令行设置级别的信息会被打印出来,大于的会被拦截。 module_init宏:该宏声明的函数会在模块被装载到内核中调用。 module_exit宏:该宏声明的函数会在模块被卸载时调用。 MODULE_LICENSE宏:指定该代码所使用的许可证协议。 MODULE_AUTHOR:描述模块作者。

03
  • Python Python中的反射机制

    概念 借用java中的定义:在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意一个方法和属性 module2.py #!/usr/bin/env python # -*- coding:utf-8 -*- __author__ = 'shouke' class TestClass: def __init__(self): pass def fun(self): pass module1.py 1、不导入模块 #!/usr/bin/env python # -*- coding:utf-8 -*- __author__ = 'shouke' if __name__ == '__main__': print(globals()) 运行结果 运行结果: {'__author__': 'shouke', '__loader__': <_frozen_importlib.SourceFileLoader object at 0x01F5C310>, '__name__': '__main__', '__builtins__': , '__package__': None, '__doc__': None, '__cached__': None, '__file__': 'F:/project/interface_project/module1.py'} 说明:globals函数返回一个map,map中的key是全局范围内对象的名字,value是该对象的实例 2、导入模块 修改module1.py代码如下 #!/usr/bin/env python # -*- coding:utf-8 -*- __author__ = 'shouke' import sys if __name__ == '__main__': print(globals()) 运行结果: {'__loader__': <_frozen_importlib.SourceFileLoader object at 0x01D9C310>, 'sys': , '__package__': None, '__builtins__': , '__author__': 'shouke', '__name__': '__main__', '__doc__': None, '__file__': 'F:/project/interface_project/module1.py', '__cached__': None} 如上,新增了带颜色部分的内容 3.导入类 修改module1.py代码如下 #!/usr/bin/env python # -*- coding:utf-8 -*- __author__ = 'shouke' from module2 import TestClass if __name__ == '__main__': print(globals()) 输出结果: {'TestClass': , '__package__': None, '__doc__': None, '__file__': 'F:/project/interface_project/module1.py', '__cached__': None, '__builtins__': , '__loader__': <_frozen_importlib.SourceFileLoader object at 0x01DFC310>, '__author__': 'shouke', '__name__': '__main__'} 如上,新增了带颜色部分的内容 4、结合getattr,callable函数 #!/usr/bin/env python # -*- coding:utf-8 -*- __author__ = 'shouke' from module2 import TestClass if __name__ == '__main__': # 动态获取类 print('动态获取类:%s'% globals()['TestClass']) print('\n') # 获取类的属性和函数 print(dir(TestClass)) print('\n') print(getattr(TestClass,'fun')) # 获取类的函数对象 print(getattr(globals()['TestClass'](),'attr')) # 获取类实例的属性对象print('\n') print(callable(getattr(TestClass,'fun'))) # 查看类的函数对象是否

    01

    09.字符设备驱动

    1.写出最底层Led_Open(),Led_Write(),Led_Read()   2.如何让内核知道下面有我们写好的操作硬件的函数呢?定义一个file_operations结构体(指向Led_Open等底层函数)。使用函数regsiter_chrdev(major,”first_drv”,&first_drv_fops)注册告诉内核(通过major索引)。   3.regsiter_chrdev被谁调用?被驱动入口函数调用。first_drv_init()   4.如何知道调用first_drv_init(),还是其他的函数呢?利用宏module_init(first_drv_init)定义一个结构体,结构体中有函数指针,指向入口函数。   5.出口函数first_drv_exit。卸载驱动unregsiter_chrdev(major,”first_drv”,&first_drv_fops)。如何知道何时来调用first_drv_exit?module_init(first_drv_exit)定义一个结构体,结构体中有函数指针,指向入口函数。

    02
    领券