当前位置:首页>python>Python pkgutil模块详细介绍

Python pkgutil模块详细介绍

  • 2026-02-11 12:36:48
Python pkgutil模块详细介绍

1. 创始时间与作者

  • 创始时间pkgutil 是 Python 标准库的一部分,最早随 Python 2.3 版本引入(2003年7月发布)。它是 Python 核心模块,随 Python 解释器一起发布,没有独立的版本号。

  • 核心开发者

    • Python 核心开发团队:pkgutil 由 Python 软件基金会的核心开发团队维护

    • Guido van Rossum:Python 语言的创始人,虽然不是 pkgutil 的直接作者,但影响了 Python 所有标准库的设计

    • 众多社区贡献者:包括 Martin v. Löwis、Fred L. Drake Jr. 等 Python 核心开发者

  • 项目定位:Python 包管理工具集,提供包和模块的发现、加载和操作功能,是 Python 包系统的基础设施。

2. 官方资源

  • Python 官方文档https://docs.python.org/3/library/pkgutil.html

  • 源代码位置https://github.com/python/cpython/blob/main/Lib/pkgutil.py

  • 相关 PEP 文档PEP 302 - New Import HooksPEP 420 - Implicit Namespace Packages

  • 安装方式:Python 标准库,无需额外安装

3. 核心功能

4. 应用场景

1. 动态发现和加载包/模块
import pkgutilimport importlib# 查找所有可用的包和模块for importermodnameispkg in pkgutil.iter_modules():print(f"{'包' if ispkg else '模块'}: {modname}")# 查找特定包的所有子模块package_name = "os"package = __import__(package_name)for importermodnameispkg in pkgutil.iter_modules(package.__path__):print(f"os 包的{'子包' if ispkg else '子模块'}: {modname}")# 动态加载模块def load_module_dynamically(module_name):"""动态加载模块"""loader = pkgutil.find_loader(module_name)if loader:module = loader.load_module(module_name)return modulereturn None# 使用my_module = load_module_dynamically("json")if my_module:print(f"成功加载模块: {my_module}")
2. 实现插件系统
# plugin_base.py - 插件基类import abcimport pkgutilimport importlibclass PluginBase(abc.ABC):"""插件基类"""@abc.abstractmethoddef execute(selfdata):"""执行插件操作"""pass@property@abc.abstractmethoddef name(self):"""插件名称"""pass# 自动发现和注册插件class PluginManager:def __init__(selfplugin_package):self.plugin_package = plugin_packageself.plugins = {}self._discover_plugins()def _discover_plugins(self):"""发现所有插件"""plugin_pkg = importlib.import_module(self.plugin_package)plugin_path = plugin_pkg.__path__for findernameispkg in pkgutil.iter_modules(plugin_path):# 动态加载插件模块module = importlib.import_module(f"{self.plugin_package}.{name}")# 查找插件类for attr_name in dir(module):attr = getattr(moduleattr_name)try:if (isinstance(attrtypeandissubclass(attrPluginBaseandattr!PluginBase):# 实例化插件并注册plugin_instance = attr()self.plugins[plugin_instance.name] = plugin_instanceexcept TypeError:continuedef execute_all(selfdata):"""执行所有插件"""results = {}for nameplugin in self.plugins.items():try:results[name] = plugin.execute(data)except Exception as e:results[name] = f"错误: {e}"return results# 使用示例# plugins/plugin1.pyclass Plugin1(PluginBase):name = "plugin1"def execute(selfdata):return f"Plugin1处理: {data.upper()}"# plugins/plugin2.py  class Plugin2(PluginBase):name = "plugin2"def execute(selfdata):return f"Plugin2处理: {data.lower()}"# 主程序manager = PluginManager("plugins")results = manager.execute_all("Hello World")print(results)
3. 访问包内资源文件
import pkgutilimport jsonimport os# 访问包内的数据文件def load_package_resource(package_nameresource_name):"""    加载包内的资源文件    """# 方法1: 使用 pkgutil.get_datatry:data = pkgutil.get_data(package_nameresource_name)if data:return data.decode('utf-8')except Exception as e:print(f"无法加载资源 {resource_name}: {e}")# 方法2: 使用 importlib.resources (Python 3.7+)try:import importlib.resourcesreturn importlib.resources.read_text(package_nameresource_name)except ImportError:passreturn None# 使用示例# 假设包结构:# mypackage/# ├── __init__.py# ├── data/# │   ├── config.json# │   └── schema.sql# 加载配置文件config_data = load_package_resource("mypackage""data/config.json")if config_data:config = json.loads(config_data)print(f"配置加载成功: {config}")# 加载SQL文件sql_data = load_package_resource("mypackage""data/schema.sql")if sql_data:print(f"SQL架构: {sql_data[:100]}...")
4. 创建和管理命名空间包
# 创建命名空间包 (Python 3.3+)# project1/some_namespace/subpackage1/__init__.py# project2/some_namespace/subpackage2/__init__.pyimport pkgutildef setup_namespace_package():"""    设置命名空间包    """# 方法1: 使用 pkgutil.extend_path__path__ = pkgutil.extend_path(__path____name__)# 方法2: 直接操作 __path__import sysimport os# 收集所有可能的路径namespace_paths = []# 从所有已安装的包中查找命名空间for findernameispkg in pkgutil.iter_modules():if name == 'some_namespace':if hasattr(finder'path'):namespace_paths.append(finder.path)# 更新 __path__if namespace_paths:__path__ = namespace_pathsreturn __path__# 使用示例if __name__ == "__main__":# 在命名空间包的 __init__.py 中调用__path__ = setup_namespace_package()# 现在可以从多个位置导入命名空间包try:from some_namespace import subpackage1from some_namespace import subpackage2print("成功导入命名空间包的两个部分")except ImportError as e:print(f"导入失败: {e}")

5. 底层逻辑与技术原理

核心架构
关键技术
  1. Python 导入系统集成

    • 基于 Python 的 sys.meta_path 和 sys.path_hooks

    • 与 importlib 模块深度集成

    • 支持标准的文件系统导入和压缩包导入

  2. 模块发现机制

    • 遍历 sys.path 中的所有路径

    • 支持递归包发现

    • 过滤隐藏文件和目录

  3. 延迟加载技术

    • 支持模块的延迟导入

    • 仅在需要时加载模块代码

    • 减少内存占用和启动时间

  4. 命名空间包实现

    • 基于 __path__ 属性的扩展机制

    • 支持多个目录合并为一个包

    • 兼容 PEP 420 隐式命名空间包

  5. 资源文件访问

    • 统一的资源定位接口

    • 支持包内文件和外部文件

    • 跨平台路径处理


6. 安装与配置

基础安装
# pkgutil 是 Python 标准库,无需安装# 直接导入即可使用import pkgutilprint(f"pkgutil 版本信息: {pkgutil.__doc__.split('\n')[0]}")
环境要求
组件最低要求推荐配置
Python 版本Python 2.3+Python 3.7+
操作系统所有 Python 支持的操作系统-
依赖库无额外依赖-
其他要求Python 标准库-
版本兼容性
import sysimport pkgutildef check_pkgutil_features():"""检查 pkgutil 功能支持"""features = {"Python 版本"sys.version.split()[0],"iter_modules"hasattr(pkgutil'iter_modules'),"walk_packages"hasattr(pkgutil'walk_packages'),"get_data"hasattr(pkgutil'get_data'),"extend_path"hasattr(pkgutil'extend_path'),"find_loader (Python 3.3+)"hasattr(pkgutil'find_loader'),"resolve_name (Python 3.9+)"hasattr(pkgutil'resolve_name'),    }for featuresupported in features.items():status = "✓ 支持" if supported else "✗ 不支持"print(f"{feature:30} {status}")if __name__ == "__main__":check_pkgutil_features()

7. 性能指标

pkgutil 作为 Python 标准库,性能高度依赖于:

  1. 文件系统 I/O 速度

  2. 导入的模块数量

  3. Python 解释器版本

典型操作性能(基于 Python 3.9,SSD 硬盘):

操作耗时说明
iter_modules()10-50ms遍历标准库模块
walk_packages() 深度 3100-300ms递归查找包
get_data() 小文件<1ms读取包内资源
find_loader()1-5ms查找模块加载器
动态导入 100 个模块200-500ms包含模块初始化

优化建议

import pkgutilimport time# 缓存发现结果以提高性能class CachedPackageDiscoverer:def __init__(self):self._cache = {}self._cache_time = {}self.cache_ttl = 60# 缓存60秒def get_modules(selfpackage_path=None):"""获取模块列表(带缓存)"""cache_key = str(package_path)# 检查缓存if (cache_key in self._cache andtime.time() -self._cache_time.get(cache_key0<self.cache_ttl):return self._cache[cache_key]# 重新发现modules = list(pkgutil.iter_modules(package_path))self._cache[cache_key] = modulesself._cache_time[cache_key] = time.time()return modules# 使用缓存discoverer = CachedPackageDiscoverer()modules = discoverer.get_modules()  # 第一次会慢modules = discoverer.get_modules()  # 第二次从缓存读取,快

8. 高级功能使用

1. 自定义模块查找器
import pkgutilimport importlib.abcimport importlib.utilimport sysclass CustomModuleFinder(importlib.abc.MetaPathFinder):"""自定义模块查找器"""def find_spec(selffullnamepathtarget=None):# 只处理特定前缀的模块if fullname.startswith("custom."):# 创建模块规范spec = importlib.util.spec_from_loader(fullname,CustomModuleLoader(),origin=f"custom://{fullname}"            )return specreturn Noneclass CustomModuleLoader(importlib.abc.Loader):"""自定义模块加载器"""def create_module(selfspec):"""创建模块对象"""# 返回 None 让导入系统创建默认模块return Nonedef exec_module(selfmodule):"""执行模块代码"""# 动态创建模块内容module.__dict__.update({"VERSION""1.0.0","greet"lambda"Hello from custom module!","__all__": ["VERSION""greet"]        })# 注册自定义查找器sys.meta_path.insert(0CustomModuleFinder())# 现在可以导入自定义模块try:import custom.exampleprint(custom.example.greet())  # 输出: Hello from custom module!except ImportError:print("自定义模块导入失败")
2. 包依赖分析器
import pkgutilimport importlibimport astclass PackageDependencyAnalyzer:"""包依赖分析器"""def __init__(self):self.dependencies = {}def analyze_package(selfpackage_name):"""分析包的依赖"""try:package = importlib.import_module(package_name)self._analyze_module(packagepackage_name)except ImportError as e:print(f"无法导入包 {package_name}: {e}")return {}return self.dependenciesdef _analyze_module(selfmodulemodule_namevisited=None):"""分析模块的依赖"""if visited is None:visited = set()if module_name in visited:returnvisited.add(module_name)# 获取模块源代码try:source = pkgutil.get_data(module.__package__module.__name__)if not source:source = pkgutil.get_data(module.__package__f"{module.__name__}.py")except:source = Noneif source:# 解析导入语句imports = self._extract_imports(source)self.dependencies[module_name] = imports# 递归分析导入的模块for imp in imports:if imp not in visited:try:submodule = importlib.import_module(imp)self._analyze_module(submoduleimpvisited)except ImportError:passdef _extract_imports(selfsource_code):"""从源代码提取导入语句"""try:tree = ast.parse(source_code.decode('utf-8'))imports = set()for node in ast.walk(tree):if isinstance(nodeast.Import):for name in node.names:imports.add(name.name)elif isinstance(nodeast.ImportFrom):if node.module:imports.add(node.module)return list(imports)except:return []# 使用示例analyzer = PackageDependencyAnalyzer()deps = analyzer.analyze_package("json")print(f"json 包的依赖: {deps}")
3. 运行时包重载器
import pkgutilimport importlibimport sysimport typesclass HotReloader:"""热重载管理器"""def __init__(self):self.module_versions = {}self.watched_modules = set()def watch_module(selfmodule_name):"""监视模块变化"""self.watched_modules.add(module_name)def reload_if_changed(selfmodule):"""如果模块有变化则重新加载"""module_name = module.__name__if module_name not in self.watched_modules:return module# 检查模块文件时间戳(简化示例)current_version = self._get_module_version(module)if module_nameinself.module_versions:if self.module_versions[module_name!current_version:print(f"重新加载模块: {module_name}")module = importlib.reload(module)self.module_versions[module_name] = current_versionreturn moduledef _get_module_version(selfmodule):"""获取模块版本标识"""# 实际实现应该检查文件修改时间或哈希值return str(id(module.__dict__))def reload_package(selfpackage_name):"""重新加载整个包及其子模块"""try:package = importlib.import_module(package_name)# 获取包的所有子模块submodules = []if hasattr(package'__path__'):for importermodnameispkg in pkgutil.walk_packages(package.__path__f"{package_name}."                ):submodules.append(modname)# 重新加载包package = importlib.reload(package)# 重新加载子模块for modname in submodules:try:importlib.reload(sys.modules[modname])except KeyError:passreturn packageexcept ImportError as e:print(f"重新加载失败: {e}")return None# 使用示例reloader = HotReloader()# 加载并监视模块import mymodulereloader.watch_module("mymodule")# 稍后检查并重新加载mymodule = reloader.reload_if_changed(mymodule)# 重新加载整个包mypackage = reloader.reload_package("mypackage")
4. 跨平台资源管理器
import pkgutilimport osimport sysimport tempfileclass ResourceManager:"""跨平台资源管理器"""def __init__(selfpackage_name):self.package_name = package_namedef get_resource_path(selfresource_name):"""获取资源文件的完整路径(临时文件)"""# 读取资源数据data = pkgutil.get_data(self.package_nameresource_name)if not data:raise FileNotFoundError(f"资源 {resource_name} 不存在")# 创建临时文件suffix = os.path.splitext(resource_name)[1or''with tempfile.NamedTemporaryFile(mode='wb'suffix=suffixdelete=False        ) as f:f.write(data)temp_path = f.namereturn temp_pathdef list_resources(selfsubdirectory=''):"""列出包内的所有资源文件"""resources = []try:package = __import__(self.package_name)if hasattr(package'__path__'):for path in package.__path__:full_path = os.path.join(pathsubdirectory)if os.path.exists(full_path):for item in os.listdir(full_path):if not item.startswith('.'):resources.append(item)except ImportError:passreturn resourcesdef copy_resource(selfresource_nametarget_path):"""复制资源文件到目标路径"""data = pkgutil.get_data(self.package_nameresource_name)if not data:return False# 确保目标目录存在os.makedirs(os.path.dirname(target_path), exist_ok=True)# 写入文件with open(target_path'wb'as f:f.write(data)return True# 使用示例manager = ResourceManager("mypackage")# 列出资源resources = manager.list_resources("data")print(f"可用资源: {resources}")# 复制资源文件if "config.json" in resources:manager.copy_resource("data/config.json""/tmp/config.json")# 获取资源临时路径temp_file = manager.get_resource_path("data/schema.sql")print(f"临时文件路径: {temp_file}")

9. 与同类工具对比

特性pkgutilimportlibsetuptools.pkg_resourcespathlib
类型标准库模块标准库模块第三方库(setuptools)标准库模块
主要用途包发现与资源访问导入系统底层接口包管理和资源访问文件路径操作
包发现⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐
资源访问⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐
动态导入⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐
命名空间包⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐
性能⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐
易用性⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐
适用场景包发现、插件系统自定义导入器打包分发应用文件路径操作

10. 企业级应用案例

  1. 插件化框架

    • Jupyter Notebook:使用 pkgutil 发现和加载扩展插件

    • PyCharm:动态加载代码检查插件

    • Django:应用发现和自动注册机制

  2. 包管理系统

    • pip:包依赖解析和发现

    • conda:环境管理和包发现

    • poetry:项目依赖管理

  3. 微服务架构

    • 名称空间包实现模块化微服务

    • 动态服务发现和注册

    • 运行时模块热重载

  4. 测试框架

    • pytest:测试用例自动发现

    • unittest:测试模块动态加载

    • nose:测试插件系统


总结

pkgutil 是 Python 包系统的核心基础设施,核心价值在于:

  1. 标准化接口:提供统一的包和模块操作接口

  2. 无依赖:Python 标准库,无需额外安装

  3. 跨平台:在所有 Python 支持的环境下工作

  4. 轻量高效:直接与 Python 导入系统集成

技术亮点

  • 包发现机制:遍历和查找 Python 包

  • 资源访问:统一的方式访问包内文件

  • 动态导入:运行时加载模块

  • 命名空间支持:实现复杂的包结构

适用场景

  • 插件系统开发:动态发现和加载插件

  • 包管理工具:包依赖分析和发现

  • 框架开发:自动注册组件和扩展

  • 资源管理:访问包内数据和配置文件

使用注意

  1. 性能考虑:大规模包发现可能较慢,需要缓存

  2. 路径安全:注意处理用户提供的路径,避免安全风险

  3. 版本兼容:不同 Python 版本的 API 可能有差异

学习资源

  • 官方文档https://docs.python.org/3/library/pkgutil.html

  • 源代码https://github.com/python/cpython/blob/main/Lib/pkgutil.py

  • 相关 PEPhttps://peps.python.org/pep-0302/,https://peps.python.org/pep-0420/

pkgutil 作为 Python 生态系统的基石之一,虽然不常直接使用,但为许多流行框架和工具提供了底层支持。它体现了 Python "内置电池"(Batteries Included)的设计哲学,是每个 Python 开发者都应该了解的核心模块。

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-02-11 13:02:35 HTTP/2.0 GET : https://f.mffb.com.cn/a/474955.html
  2. 运行时间 : 0.131710s [ 吞吐率:7.59req/s ] 内存消耗:4,742.37kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=1bf665015559e0f2d50f69f80c28f3a0
  1. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/public/index.php ( 0.79 KB )
  2. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/autoload.php ( 0.17 KB )
  3. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/autoload_real.php ( 2.49 KB )
  4. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/platform_check.php ( 0.90 KB )
  5. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/ClassLoader.php ( 14.03 KB )
  6. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/autoload_static.php ( 4.90 KB )
  7. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/helper.php ( 8.34 KB )
  8. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-validate/src/helper.php ( 2.19 KB )
  9. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/helper.php ( 1.47 KB )
  10. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/stubs/load_stubs.php ( 0.16 KB )
  11. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Exception.php ( 1.69 KB )
  12. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-container/src/Facade.php ( 2.71 KB )
  13. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/deprecation-contracts/function.php ( 0.99 KB )
  14. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/polyfill-mbstring/bootstrap.php ( 8.26 KB )
  15. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/polyfill-mbstring/bootstrap80.php ( 9.78 KB )
  16. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/var-dumper/Resources/functions/dump.php ( 1.49 KB )
  17. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-dumper/src/helper.php ( 0.18 KB )
  18. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/var-dumper/VarDumper.php ( 4.30 KB )
  19. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/App.php ( 15.30 KB )
  20. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-container/src/Container.php ( 15.76 KB )
  21. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/container/src/ContainerInterface.php ( 1.02 KB )
  22. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/provider.php ( 0.19 KB )
  23. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Http.php ( 6.04 KB )
  24. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/helper/Str.php ( 7.29 KB )
  25. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Env.php ( 4.68 KB )
  26. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/common.php ( 0.03 KB )
  27. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/helper.php ( 18.78 KB )
  28. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Config.php ( 5.54 KB )
  29. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/app.php ( 0.95 KB )
  30. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/cache.php ( 0.78 KB )
  31. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/console.php ( 0.23 KB )
  32. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/cookie.php ( 0.56 KB )
  33. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/database.php ( 2.48 KB )
  34. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/facade/Env.php ( 1.67 KB )
  35. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/filesystem.php ( 0.61 KB )
  36. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/lang.php ( 0.91 KB )
  37. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/log.php ( 1.35 KB )
  38. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/middleware.php ( 0.19 KB )
  39. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/route.php ( 1.89 KB )
  40. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/session.php ( 0.57 KB )
  41. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/trace.php ( 0.34 KB )
  42. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/view.php ( 0.82 KB )
  43. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/event.php ( 0.25 KB )
  44. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Event.php ( 7.67 KB )
  45. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/service.php ( 0.13 KB )
  46. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/AppService.php ( 0.26 KB )
  47. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Service.php ( 1.64 KB )
  48. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Lang.php ( 7.35 KB )
  49. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/lang/zh-cn.php ( 13.70 KB )
  50. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/initializer/Error.php ( 3.31 KB )
  51. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/initializer/RegisterService.php ( 1.33 KB )
  52. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/services.php ( 0.14 KB )
  53. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/service/PaginatorService.php ( 1.52 KB )
  54. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/service/ValidateService.php ( 0.99 KB )
  55. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/service/ModelService.php ( 2.04 KB )
  56. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-trace/src/Service.php ( 0.77 KB )
  57. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Middleware.php ( 6.72 KB )
  58. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/initializer/BootService.php ( 0.77 KB )
  59. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/Paginator.php ( 11.86 KB )
  60. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-validate/src/Validate.php ( 63.20 KB )
  61. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/Model.php ( 23.55 KB )
  62. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/Attribute.php ( 21.05 KB )
  63. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/AutoWriteData.php ( 4.21 KB )
  64. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/Conversion.php ( 6.44 KB )
  65. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/DbConnect.php ( 5.16 KB )
  66. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/ModelEvent.php ( 2.33 KB )
  67. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/RelationShip.php ( 28.29 KB )
  68. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/contract/Arrayable.php ( 0.09 KB )
  69. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/contract/Jsonable.php ( 0.13 KB )
  70. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/contract/Modelable.php ( 0.09 KB )
  71. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Db.php ( 2.88 KB )
  72. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/DbManager.php ( 8.52 KB )
  73. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Log.php ( 6.28 KB )
  74. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Manager.php ( 3.92 KB )
  75. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/log/src/LoggerTrait.php ( 2.69 KB )
  76. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/log/src/LoggerInterface.php ( 2.71 KB )
  77. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Cache.php ( 4.92 KB )
  78. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/simple-cache/src/CacheInterface.php ( 4.71 KB )
  79. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/helper/Arr.php ( 16.63 KB )
  80. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/cache/driver/File.php ( 7.84 KB )
  81. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/cache/Driver.php ( 9.03 KB )
  82. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/CacheHandlerInterface.php ( 1.99 KB )
  83. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/Request.php ( 0.09 KB )
  84. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Request.php ( 55.78 KB )
  85. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/middleware.php ( 0.25 KB )
  86. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Pipeline.php ( 2.61 KB )
  87. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-trace/src/TraceDebug.php ( 3.40 KB )
  88. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/middleware/SessionInit.php ( 1.94 KB )
  89. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Session.php ( 1.80 KB )
  90. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/session/driver/File.php ( 6.27 KB )
  91. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/SessionHandlerInterface.php ( 0.87 KB )
  92. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/session/Store.php ( 7.12 KB )
  93. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Route.php ( 23.73 KB )
  94. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/RuleName.php ( 5.75 KB )
  95. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/Domain.php ( 2.53 KB )
  96. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/RuleGroup.php ( 22.43 KB )
  97. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/Rule.php ( 26.95 KB )
  98. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/RuleItem.php ( 9.78 KB )
  99. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/route/app.php ( 1.72 KB )
  100. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/facade/Route.php ( 4.70 KB )
  101. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/dispatch/Controller.php ( 4.74 KB )
  102. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/Dispatch.php ( 10.44 KB )
  103. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/controller/Index.php ( 4.81 KB )
  104. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/BaseController.php ( 2.05 KB )
  105. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/facade/Db.php ( 0.93 KB )
  106. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/connector/Mysql.php ( 5.44 KB )
  107. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/PDOConnection.php ( 52.47 KB )
  108. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/Connection.php ( 8.39 KB )
  109. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/ConnectionInterface.php ( 4.57 KB )
  110. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/builder/Mysql.php ( 16.58 KB )
  111. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/Builder.php ( 24.06 KB )
  112. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/BaseBuilder.php ( 27.50 KB )
  113. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/Query.php ( 15.71 KB )
  114. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/BaseQuery.php ( 45.13 KB )
  115. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/TimeFieldQuery.php ( 7.43 KB )
  116. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/AggregateQuery.php ( 3.26 KB )
  117. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/ModelRelationQuery.php ( 20.07 KB )
  118. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/ParamsBind.php ( 3.66 KB )
  119. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/ResultOperation.php ( 7.01 KB )
  120. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/WhereQuery.php ( 19.37 KB )
  121. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/JoinAndViewQuery.php ( 7.11 KB )
  122. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/TableFieldInfo.php ( 2.63 KB )
  123. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/Transaction.php ( 2.77 KB )
  124. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/log/driver/File.php ( 5.96 KB )
  125. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/LogHandlerInterface.php ( 0.86 KB )
  126. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/log/Channel.php ( 3.89 KB )
  127. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/event/LogRecord.php ( 1.02 KB )
  128. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/Collection.php ( 16.47 KB )
  129. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/facade/View.php ( 1.70 KB )
  130. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/View.php ( 4.39 KB )
  131. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Response.php ( 8.81 KB )
  132. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/response/View.php ( 3.29 KB )
  133. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Cookie.php ( 6.06 KB )
  134. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-view/src/Think.php ( 8.38 KB )
  135. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/TemplateHandlerInterface.php ( 1.60 KB )
  136. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-template/src/Template.php ( 46.61 KB )
  137. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-template/src/template/driver/File.php ( 2.41 KB )
  138. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-template/src/template/contract/DriverInterface.php ( 0.86 KB )
  139. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/runtime/temp/067d451b9a0c665040f3f1bdd3293d68.php ( 11.98 KB )
  140. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-trace/src/Html.php ( 4.42 KB )
  1. CONNECT:[ UseTime:0.000588s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.000908s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.002512s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.003471s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.000852s ]
  6. SELECT * FROM `set` [ RunTime:0.000249s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.000608s ]
  8. SELECT * FROM `article` WHERE `id` = 474955 LIMIT 1 [ RunTime:0.006689s ]
  9. UPDATE `article` SET `lasttime` = 1770786155 WHERE `id` = 474955 [ RunTime:0.005804s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 66 LIMIT 1 [ RunTime:0.003428s ]
  11. SELECT * FROM `article` WHERE `id` < 474955 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.000549s ]
  12. SELECT * FROM `article` WHERE `id` > 474955 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.003181s ]
  13. SELECT * FROM `article` WHERE `id` < 474955 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.005505s ]
  14. SELECT * FROM `article` WHERE `id` < 474955 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.023150s ]
  15. SELECT * FROM `article` WHERE `id` < 474955 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.005759s ]
0.133431s