当前位置:首页>python>别再傻傻一次性加载数据了!Python生成器让你节省99%的内存

别再傻傻一次性加载数据了!Python生成器让你节省99%的内存

  • 2026-07-01 20:37:04
别再傻傻一次性加载数据了!Python生成器让你节省99%的内存

大家好,我是沉默小皮,让大家更容易的学习Python3,今天我们来看下:迭代器与生成器。


一、先聊聊迭代器到底是什么

咱们平时写for循环遍历列表,那个列表本身不是迭代器,但for循环在后台会悄悄把它转成迭代器。

简单理解:迭代器就像是一个“遥控器”,能让你逐个访问集合里的元素,而且还能记住当前访问到哪个位置了。

# 给你一个水果列表
fruits = ["苹果""香蕉""橘子""葡萄"]

# 用 iter() 把它变成一个迭代器
fruit_iterator = iter(fruits)

# 用 next() 一个一个取出来
print(next(fruit_iterator))  # 苹果
print(next(fruit_iterator))  # 香蕉
print(next(fruit_iterator))  # 橘子
print(next(fruit_iterator))  # 葡萄

# 再来一次就没了,会报 StopIteration 异常
# print(next(fruit_iterator))  # 报错!

迭代器的三个特点

  1. 只能往前:你没办法回到上一个元素
  2. 惰性取值:不会一次性把所有元素都准备好,而是你问它要的时候它才给下一个
  3. 一次性:遍历完就结束了,想再遍历一次得重新创建

可能有朋友会问:“我直接for fruit in fruits不是更方便吗?搞个迭代器出来多此一举吧?”

其实for循环本身就是迭代器的语法糖。上面那段for fruit in fruits,Python在底层做的正是:先iter(fruits)拿到迭代器,然后不断next()直到捕获StopIteration。理解迭代器,你就理解了for循环的底层原理。


二、除了for循环,还能怎么用迭代器?

如果你不想用for,也可以自己用while循环配合next()来手动控制:

fruits = ["苹果""香蕉""橘子""葡萄"]
it = iter(fruits)

whileTrue:
try:
        fruit = next(it)
        print(f"处理:{fruit}")
except StopIteration:
        print("所有水果都处理完了")
break

这种写法在你需要“有条件地提前终止”或者“两个迭代器交替取值”时特别有用。


三、自己动手写一个迭代器

如果你想让自己定义的类也能被for循环遍历,就需要实现两个特殊方法:__iter__()__next__()

# 场景:实现一个“周几”迭代器,从周一开始,最多指定天数
classWeekIterator:
def__init__(self, max_days):
        self.weeks = ["周一""周二""周三""周四""周五""周六""周日"]
        self.max_days = max_days  # 最多迭代多少天
        self.index = 0

def__iter__(self):
# 返回迭代器对象本身
return self

def__next__(self):
if self.index >= self.max_days:
# 超过次数了,抛出异常终止迭代
raise StopIteration

        day = self.weeks[self.index % 7]  # 超过7天就循环
        self.index += 1
return day

# 使用这个迭代器:取前10天
week_iter = WeekIterator(10)
for day in week_iter:
    print(day, end=' ')  # 周一 周二 周三 周四 周五 周六 周日 周一 周二 周三

这里我踩过坑:刚学的时候总是忘记在迭代结束时raise StopIteration。如果没有这个异常,for循环会永远执行下去,而且你还不知道为什么。记住:__next__方法里必须有一个明确的出口来触发StopIteration


四、生成器:Python给你的“偷懒神器”

看完上面自己实现迭代器的代码,你可能觉得:又要写__iter__,又要写__next__,还要手动维护状态,好麻烦啊!

生成器就是用来解决这个麻烦的——它让你用写普通函数的方式,就能得到一个迭代器。

4.1 生成器的核心:yield

只要函数里用到了yield关键字,这个函数就不再是普通函数了,而是一个生成器函数。调用它不会立刻执行函数体,而是返回一个生成器对象。

# 场景:倒计时功能
defcountdown(n):
    print("开始倒计时啦")
while n > 0:
yield n  # 在这里“暂停”,把n返回给调用者
        n -= 1
    print("倒计时结束!")

# 调用生成器函数,得到一个生成器对象
cd = countdown(3)
print(cd)  # <generator object countdown at 0x...>

# 用 next() 一步步触发
print(next(cd))  # 打印:开始倒计时啦 \n 3
print(next(cd))  # 2
print(next(cd))  # 1
print(next(cd))  # 打印:倒计时结束! \n 然后抛出 StopIteration

yield的神奇之处

  • 函数执行到yield就“暂停”了,但函数内的局部变量(比如这里的n)会被保留
  • 下次调用next()时,从上次暂停的地方继续执行下一行代码
  • 这种“暂停-恢复”的能力,让一个函数可以分多次“吐出”结果

4.2 生成器 vs 普通函数:用个例子说清楚

假设你需要产生前100万个整数:

# 普通函数:一次性把所有结果放到列表里返回
defget_numbers_normal(n):
    result = []
for i in range(n):
        result.append(i)
return result

# 生成器函数:边产生边给,不存列表
defget_numbers_generator(n):
for i in range(n):
yield i

# 测试内存占用(不要在生产环境这么测,这里示意)
# 普通方式:会创建一个包含100万个整数的列表,内存占用很大
nums_normal = get_numbers_normal(1_000_000)

# 生成器方式:几乎不占内存,只是产生了一个生成器对象
nums_gen = get_numbers_generator(1_000_000)

对于调用方来说,两种方式都可以用for循环遍历。但背后的内存消耗天差地别。


五、生成器的实战价值

5.1 处理超大文件(最经典的场景)

# 场景:分析一个10GB的服务器日志,找出所有包含"ERROR"的行
defread_large_file(file_path):
with open(file_path, 'r', encoding='utf-8'as f:
for line in f:
# 每次只给出一行,不一次性加载整个文件
yield line.strip()

# 使用生成器逐条处理
for log_line in read_large_file("huge_server.log"):
if"ERROR"in log_line:
        print(f"发现错误: {log_line[:100]}...")  # 只打印前100个字符

如果用普通方式把10GB文件全部读进内存,电脑直接卡死。生成器让你能够“边读边处理”,内存占用始终只有一行文本的大小。

5.2 表示无限序列

有些序列在理论上是无限的,比如所有自然数、斐波那契数列。用列表你永远存不下,但生成器可以:

# 斐波那契数列生成器(无限版本)
deffibonacci():
    a, b = 01
whileTrue:  # 无限循环
yield a
        a, b = b, a + b

# 只取前10个
fib = fibonacci()
for i in range(10):
    print(next(fib), end=' ')  # 0 1 1 2 3 5 8 13 21 34

# 想取第1000个也没问题,不会提前计算前面的所有值

5.3 生成器表达式:更简洁的写法

如果你觉得写一个完整的yield函数还有点重,可以用生成器表达式。它长得像列表推导式,但把方括号换成圆括号:

# 列表推导式:一次性生成所有平方数,占用内存
squares_list = [x**2for x in range(10000)]

# 生成器表达式:惰性求值,几乎不占内存
squares_gen = (x**2for x in range(10000))

# 用的时候再取
for val in squares_gen:
if val > 100:
break
    print(val, end=' ')  # 0 1 4 9 16 25 36 49 64 81 100
对比项
列表推导式 [...]
生成器表达式 (...)
内存占用
一次性分配所有元素
极低,边用边生成
能否重复迭代
可以
不能,迭代完就没了
适用场景
数据量小、需要多次使用
数据量大、只需遍历一次

这里我踩过坑:有一次我写代码解析一个几万行的配置文件,用了列表推导式,程序内存飙升到几百兆。后来改成生成器表达式,内存降到几十KB。从那以后,只要处理的数据我不确定大小,都先用生成器表达式,发现需要多次遍历再转成列表也不迟。


六、几个容易混淆的点

6.1 生成器函数 vs 普通函数:调用方式一样,行为完全不同

defnormal_func():
return [123]

defgen_func():
yield1
yield2
yield3

# 调用普通函数:直接拿到返回值
result = normal_func()
print(result)  # [1, 2, 3]

# 调用生成器函数:拿到的是生成器对象,函数体还没执行
gen = gen_func()
print(gen)  # <generator object gen_func at 0x...>
print(list(gen))  # [1, 2, 3]  需要迭代才能拿到值

6.2 生成器只能迭代一次

gen = (x for x in range(5))

# 第一次迭代
print(list(gen))  # [0, 1, 2, 3, 4]

# 第二次迭代
print(list(gen))  # []  空的!因为生成器已经“耗尽”了

# 想再用?重新创建一个生成器
gen2 = (x for x in range(5))

几点实在的经验

  1. 不要把生成器和列表搞混
    生成器没有长度、不支持索引、不能切片、不能重复迭代。如果你需要这些功能,请用列表。生成器的价值是用“一次性遍历”换“极低内存”。

  2. StopIteration异常是正常流程,不是错误
    它只是告诉调用方“没数据了”。你自己写迭代器或生成器时,不需要手动捕获它,for循环会帮你处理。只有在手动调用next()时才需要关注。

  3. 生成器里的return不等于函数结束
    在生成器函数里,return会触发StopIteration异常,同时return的值会作为异常的参数。但实际开发中,生成器里很少用return,更常见的做法是让循环自然结束或者用if判断主动return来终止。

  4. 生成器的性能优势主要体现在内存,而不是速度
    生成器不会让你的代码跑得更快(甚至可能比列表推导式稍慢一点点)。它的价值是用可接受的执行时间换宝贵的内存空间。内存不够时,生成器是你的救命稻草。

  5. 什么时候该用生成器?

    什么时候不该用?

    • 数据量小(几十几百个),且需要多次遍历
    • 需要随机访问(取第5个、第100个)
    • 代码可读性优先,且生成器逻辑过于复杂
    • 处理大文件、大数据库查询结果、网络流数据
    • 需要表示无限序列
    • 只想遍历一次,而且数据量较大
  6. 调试生成器时有点麻烦
    生成器不支持断点调试时直接看内部状态(因为它是懒加载的)。如果生成器逻辑复杂,建议先写成普通函数调试好,再转成生成器版本。或者把生成器里的yield临时改成print,看看到底产生了哪些值。

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-07-03 01:00:39 HTTP/2.0 GET : https://f.mffb.com.cn/a/496868.html
  2. 运行时间 : 0.448085s [ 吞吐率:2.23req/s ] 内存消耗:4,577.88kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=1ba1c83df554bfd2f77c880ad4c43266
  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.001090s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.001688s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.007961s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.003119s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.001703s ]
  6. SELECT * FROM `set` [ RunTime:0.003069s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.001030s ]
  8. SELECT * FROM `article` WHERE `id` = 496868 LIMIT 1 [ RunTime:0.010633s ]
  9. UPDATE `article` SET `lasttime` = 1783011639 WHERE `id` = 496868 [ RunTime:0.025589s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 66 LIMIT 1 [ RunTime:0.000651s ]
  11. SELECT * FROM `article` WHERE `id` < 496868 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.030625s ]
  12. SELECT * FROM `article` WHERE `id` > 496868 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.059953s ]
  13. SELECT * FROM `article` WHERE `id` < 496868 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.080843s ]
  14. SELECT * FROM `article` WHERE `id` < 496868 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.024722s ]
  15. SELECT * FROM `article` WHERE `id` < 496868 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.099848s ]
0.449708s