当前位置:首页>python>Python零基础入门(四):模块与包导入

Python零基础入门(四):模块与包导入

  • 2026-07-03 02:16:42
Python零基础入门(四):模块与包导入

前言

前三篇我们一路从环境搭建与数据类型、运算符与条件判断学到了面向对象编程基础。你写的代码越来越长、功能越来越多——于是问题来了:所有代码都塞在一个文件里,动辄上千行,该怎么管?

答案就是模块(Module) 。模块让你把代码拆分到多个文件中,各自独立、按需复用。Python 标准库就是由数百个模块组成的,学会模块机制,你才算真正掌握了 Python 的"拼图"方式。


一、模块是什么?

一个.py文件就是一个模块。文件名去掉 .py 后缀就是模块名。

my_project/├── main.py          # 入口文件├── calculator.py    # 模块:计算器└── utils.py         # 模块:工具函数

在 calculator.py 中写一些函数:

# calculator.py"""计算器模块 —— 提供基本的数学运算"""def add(a, b):    return a + bdef subtract(a, b):    return a - bdef multiply(a, b):    return a * bdef divide(a, b):    if b == 0:        raise ValueError("除数不能为零")    return a / b# 模块级常量PI = 3.14159

在 main.py 中使用它:

# main.pyimport calculatorprint(calculator.add(10, 5))      # 15print(calculator.PI)              # 3.14159

就是这么简单——import 模块名,然后用 模块名.函数名() 调用。模块让代码组织变得自然:一个文件负责一类功能。


二、import 的四种写法

Python 的导入语法非常灵活,四种写法应付不同场景:

2.1 最基础:import 模块名

import mathprint(math.sqrt(16))   # 4.0print(math.pi)         # 3.141592653589793

每次使用都要带 模块名. 前缀,清晰明了,不会污染当前命名空间。

2.2 起别名:import 模块名 as 别名

import numpy as npimport pandas as pdimport matplotlib.pyplot as pltarr = np.array([1, 2, 3])data = pd.DataFrame({"a": [1, 2, 3]})plt.plot([1, 2, 3], [4, 5, 6])

社区有约定俗成的别名:numpy → nppandas → pdmatplotlib.pyplot → plt。跟着约定走,别人一看就懂。

2.3 按需导入:from 模块 import 名字

from math import sqrt, pi, cosprint(sqrt(25))   # 5.0 —— 直接写函数名,不用加 math.print(pi)         # 3.141592653589793print(cos(0))     # 1.0

好处是代码更简洁,坏处是可能和当前文件里的函数重名。使用时注意避让。

2.4 全量导入(谨慎使用):from 模块 import *

from math import *print(sin(0))     # 0.0print(e)          # 2.718281828459045

不推荐!  它会把这个模块里所有公开的名字全部塞进当前命名空间,你根本不知道导入了什么,极易造成命名冲突。只在极少数场景(如 tkinter 的常量定义)用到。


三、if __name__ == "__main__" 到底什么意思?

这是 Python 面试必考题,也是每个 Python 文件都该有的"入口守门员"。

3.1 先看现象

创建 greet.py

# greet.pydef hello(name):    return f"你好,{name}!"print(f"greet.py 的 __name__ 是:{__name__}")if __name__ == "__main__":    print("我作为主程序运行")    print(hello("世界"))

直接运行它:

$ python greet.pygreet.py 的 __name__ 是:__main__我作为主程序运行你好,世界!

再创建 app.py 导入它:

# app.pyimport greetprint("app.py 结束")
$ python app.pygreet.py 的 __name__ 是:greetapp.py 结束

3.2 规则很简单

运行方式
__name__
 的值
直接执行 (python xxx.py)
"__main__"
被导入 (import xxx)
模块名 "xxx"

所以 if __name__ == "__main__": 的意思是:这个文件只有当被直接运行时才执行这段代码,被导入时跳过

3.3 为什么需要它?

# 不好 —— 每次导入都会执行print("模块加载中...")run_tests()          # 别人 import 时也会跑测试!# 好 —— 只在直接运行时执行if __name__ == "__main__":    print("模块加载中...")    run_tests()      # 只有 python xxx.py 时才跑

建议:每个 .py 文件都加上 if __name__ == "__main__":,哪怕里面暂时只有一行 pass。这是一个好习惯,日后扩展时才不会踩坑。


四、模块搜索路径:Python 怎么找到你的模块?

当你写 import something,Python 会按顺序在以下路径中搜索:

import sysfor p in sys.path:    print(p)

典型输出:

(当前脚本所在目录)/usr/lib/python3.10/usr/lib/python3.10/lib-dynload/home/user/miniconda3/envs/myproject/lib/python3.10/site-packages

搜索顺序:

  1. 1. 当前脚本所在目录(最优先)
  2. 2. PYTHONPATH环境变量中指定的目录
  3. 3. 标准库目录
  4. 4. 第三方包目录site-packages

如果模块找不到,先检查这几处。常见解决方案:

# 临时添加搜索路径(不推荐,但应急可用)import syssys.path.append("/path/to/your/module")

更好的做法是正确组织项目结构,用包来管理。


五、包(Package):组织模块的文件夹

模块多了怎么办?用——包含 __init__.py 的文件夹就是包。

5.1 包的基本结构

my_project/├── main.py├── mathlib/                # 这是一个包│   ├── __init__.py          # 标识此文件夹为包(可为空)│   ├── arithmetic.py        # 子模块:四则运算│   └── advanced.py          # 子模块:高级运算└── utils/                   # 另一个包    ├── __init__.py    ├── fileio.py    └── logger.py

__init__.py 是包的身份证。Python 3.3 起虽然没有 __init__.py 也不报错(称为"命名空间包"),但建议始终放一个,即使是空文件,明确表示"这是一个包"。

5.2 导入包中的模块

# 方式一:导入完整路径import mathlib.arithmeticprint(mathlib.arithmetic.add(3, 4))# 方式二:from 导入from mathlib.arithmetic import add, subtractprint(add(3, 4))# 方式三:from 包导入模块from mathlib import advancedprint(advanced.power(2, 10))# 方式四:别名import mathlib.advanced as advprint(adv.sqrt(16))

5.3 用 init.py 统一出口

__init__.py 不只是标识,还能控制 from 包 import * 的行为和简化接口:

# mathlib/__init__.pyfrom .arithmetic import add, subtract, multiply, dividefrom .advanced import power, sqrt, factorial__all__ = ["add", "subtract", "multiply", "divide", "power", "sqrt", "factorial"]

这样外部使用变得非常简洁:

from mathlib import add, powerprint(add(1, 2))     # 3print(power(2, 8))   # 256

5.4 相对导入:包内部互相引用

在包内部,子模块之间引用用相对导入

# mathlib/advanced.pyfrom .arithmetic import multiply    # . 表示"当前包"def power(base, exp):    """用 multiply 实现乘方"""    result = 1    for _ in range(exp):        result = multiply(result, base)    return result# mathlib/arithmetic.py 中引用上级同级from . import advanced              # 导入同一个包下的 advancedfrom ..utils import logger          # .. 表示上级包

相对导入规则速查:

符号
含义
.
当前包(本文件所在目录)
..
上级包
...
上上级包
.module
当前包下的 module 模块
..package.module
上级包下的 package 的子模块

注意:相对导入只能在包内部使用。如果直接运行一个使用了相对导入的 .py 文件(如 python arithmetic.py),会报错 ImportError: attempted relative import with no known parent package。此时需要从包外部以模块方式运行(python -m mathlib.arithmetic)。


六、常用标准库速览

Python 自带了大量实用模块,下面是最常用的一批:

模块
用途
一行示例
os
操作系统接口(路径、环境变量)
os.path.join("a", "b")
sys
系统参数与运行时信息
sys.argv[1]
 → 获取命令行参数
math
数学函数
math.sqrt(16)
 → 4.0
random
随机数
random.randint(1, 10)
datetime
日期时间处理
datetime.datetime.now()
json
JSON 编解码
json.loads('{"a": 1}')
re
正则表达式
re.search(r"\d+", "abc123")
os.path
路径操作
os.path.exists("/tmp/test.txt")
shutil
高级文件操作
shutil.copy("a.txt", "b.txt")
argparse
命令行参数解析
构建专业的命令行工具
typing
类型提示
def f(x: int) -> str:
# 综合示例:5 行代码创建一个带时间戳的文件import jsonfrom datetime import datetimedata = {"name": "测试", "timestamp": datetime.now().isoformat(), "value": 42}with open("output.json", "w", encoding="utf-8") as f:    json.dump(data, f, ensure_ascii=False, indent=2)print("文件已生成:output.json")

七、第三方包与 pip

Python 的"标准库"只是开胃菜,真正的盛宴在 PyPI(Python Package Index),上面的第三方包数量超过 40 万。

7.1 基础操作

# 安装pip install requests# 安装指定版本pip install numpy==1.24.0# 卸载pip uninstall requests# 查看已安装的包pip list# 导出依赖列表pip freeze > requirements.txt# 根据依赖列表批量安装pip install -r requirements.txt

国内用户建议使用清华镜像加速,详见本系列第一篇的 1.4 节。

7.2 新手必知的几个第三方包

包名
一句话介绍
requests
HTTP 请求,比标准库的 urllib 好用百倍
numpy
科学计算的基础——高性能多维数组
pandas
数据分析利器——DataFrame 表格处理
matplotlib
数据可视化——画图、图表
pillow
图像处理——打开、编辑、保存图片
flask
轻量级 Web 框架——几行代码搭网站

7.3 靠谱的项目依赖方案

# 用虚拟环境隔离依赖(第一篇讲过)conda create -n myproject python=3.10 -yconda activate myproject# 安装依赖pip install requests pandas matplotlib# 锁定版本pip freeze > requirements.txt

requirements.txt 示例:

numpy==1.24.0pandas==2.1.0matplotlib==3.7.1requests==2.31.0

把 requirements.txt 放在项目根目录,其他人 pip install -r requirements.txt 就能复现你的环境。


八、动手练习

  1. 1. 创建一个 string_utils.py 模块,包含 reverse_str(text)(反转字符串)和 count_words(text)(统计单词数)两个函数。在 main.py 中导入并使用。
  2. 2. 建一个包 shapes,包含 circle.py(面积、周长)和 rectangle.py(面积、周长)。在 __init__.py 中统一导出接口,然后在 main.py 中用 from shapes import circle_area, rect_area 的方式调用。
  3. 3. 在练习 2 的包中,让 circle.py 和 rectangle.py 使用 if __name__ == "__main__": 各自包含一段测试代码。
  4. 4. 安装 requests 包,写一个脚本请求 https://api.github.com,打印返回的 JSON 中 current_user_url 字段的值。

九、小结

本篇我们从"一个文件就是一个模块"出发,系统掌握了 Python 的模块与包体系:

  • • import 的四种写法importimport...asfrom...importfrom...import *,各有适用场景。
  • •  __name__魔法:区分"直接运行"与"被导入",每个文件都该加上 if __name__ == "__main__":
  • • 模块搜索路径sys.path 决定 Python 在哪找模块,理解它就不会再困惑"为什么找不到模块"。
  • • :用文件夹 + __init__.py 组织模块,相对导入让包内部互相引用,__init__.py 统一对外接口。
  • • 标准库与第三方包ossysjsondatetime 等开箱即用,pip install 打开更广阔的世界。

模块是 Python 代码复用的基础单元。掌握了模块,你就能写出"分而治之"的干净代码,而不是一个几千行的巨型文件。


本文首发于微信公众号「羽您码上聊」,欢迎关注获取更多技术内容。

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-07-04 03:11:24 HTTP/2.0 GET : https://f.mffb.com.cn/a/500355.html
  2. 运行时间 : 0.089347s [ 吞吐率:11.19req/s ] 内存消耗:4,770.30kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=519b0eb4d7a2e20d1320c09364383795
  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.000586s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.000801s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.000315s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.000254s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.000481s ]
  6. SELECT * FROM `set` [ RunTime:0.000195s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.000514s ]
  8. SELECT * FROM `article` WHERE `id` = 500355 LIMIT 1 [ RunTime:0.000458s ]
  9. UPDATE `article` SET `lasttime` = 1783105884 WHERE `id` = 500355 [ RunTime:0.005411s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 66 LIMIT 1 [ RunTime:0.000325s ]
  11. SELECT * FROM `article` WHERE `id` < 500355 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.000626s ]
  12. SELECT * FROM `article` WHERE `id` > 500355 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.000441s ]
  13. SELECT * FROM `article` WHERE `id` < 500355 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.001255s ]
  14. SELECT * FROM `article` WHERE `id` < 500355 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.001178s ]
  15. SELECT * FROM `article` WHERE `id` < 500355 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.010009s ]
0.090934s