当前位置:首页>python>Python collections模块——增强的数据容器

Python collections模块——增强的数据容器

  • 2026-06-30 09:06:57
Python collections模块——增强的数据容器

一、collections模块概述

collections 是 Python 标准库中提供增强版容器数据类型的模块。它扩展了内置的 listtupledictset 等基础容器,提供了更强大、更便捷的数据结构,帮助开发者解决特定场景下的数据存储和处理需求。

from collections import Counter, defaultdict, deque, namedtuple, OrderedDict

# 示例:Counter 统计频率
words = ['apple''banana''apple''orange''banana''apple']
counter = Counter(words)
print(counter)  # Counter({'apple': 3, 'banana': 2, 'orange': 1})

二、namedtuple——带字段名的元组

2.1 基本用法

namedtuple 创建了一个轻量级、不可变的数据类,它像元组一样高效,但可以通过字段名访问元素,提高代码可读性。

from collections import namedtuple

# 定义 namedtuple 类型
Point = namedtuple('Point', ['x''y'])
# 或使用字符串:namedtuple('Point', 'x y')

# 创建实例
p1 = Point(1020)
p2 = Point(x=30, y=40)

print(p1.x, p1.y)      # 10 20(属性访问)
print(p1[0], p1[1])    # 10 20(索引访问)
print(p1)              # Point(x=10, y=20)

2.2 特性

from collections import namedtuple

Person = namedtuple('Person', ['name''age''city'])

# 创建
p = Person('张三'25'北京')

# 解包
name, age, city = p

# 替换字段(返回新实例)
p_new = p._replace(age=26)

# 转为字典
print(p._asdict())  # {'name': '张三', 'age': 25, 'city': '北京'}

# 获取字段名
print(p._fields)    # ('name', 'age', 'city')

2.3 适用场景

  • • 替代简单的类(不需要方法时)
  • • 表示数据记录(如 CSV 行、数据库行)
  • • 提高代码可读性
# 实战:处理 CSV 数据
from collections import namedtuple
import csv

withopen('users.csv''r'as f:
    reader = csv.reader(f)
    headers = next(reader)
    User = namedtuple('User', headers)

for row in reader:
        user = User(*row)
print(f"{user.name} - {user.email}")

三、deque——双端队列

3.1 基本用法

deque(double-ended queue,双端队列)是一个线程安全的队列,支持从两端快速添加和弹出元素,性能优于 list 的头部操作。

from collections import deque

# 创建
dq = deque([123])
print(dq)  # deque([1, 2, 3])

# 从右边添加
dq.append(4)          # [1, 2, 3, 4]
dq.appendleft(0)      # [0, 1, 2, 3, 4]

# 从右边弹出
dq.pop()              # 返回 4,deque([0, 1, 2, 3])
dq.popleft()          # 返回 0,deque([1, 2, 3])

# 扩展
dq.extend([45])     # [1, 2, 3, 4, 5]
dq.extendleft([0])    # [0, 1, 2, 3, 4, 5]

3.2 限制长度

from collections import deque

# 固定长度,超出自动移除另一端
dq = deque(maxlen=3)
dq.extend([123])
print(dq)             # deque([1, 2, 3], maxlen=3)

dq.append(4)
print(dq)             # deque([2, 3, 4], maxlen=3)  # 1 被移除

3.3 常用方法

from collections import deque

dq = deque([12321])

# 旋转
dq.rotate(1)    # 右旋转1步: [1, 1, 2, 3, 2]
dq.rotate(-1)   # 左旋转1步: [2, 3, 2, 1, 1]

# 计数
print(dq.count(2))  # 2

# 清空
dq.clear()

# 反转
dq = deque([123])
dq.reverse()
print(dq)           # deque([3, 2, 1])

3.4 适用场景

  • • 队列和栈的实现
  • • 固定大小的缓存(如 LRU Cache)
  • • 滑动窗口问题
# 实战:实现简单队列
from collections import deque

task_queue = deque()
task_queue.append('任务1')
task_queue.append('任务2')
task_queue.append('任务3')

while task_queue:
    task = task_queue.popleft()
print(f"处理: {task}")

四、Counter——计数器

4.1 基本用法

Counter 是 dict 的子类,用于统计可哈希对象的数量。

from collections import Counter

# 从列表创建
words = ['a''b''c''a''b''a']
counter = Counter(words)
print(counter)      # Counter({'a': 3, 'b': 2, 'c': 1})

# 从字符串创建
char_counter = Counter('hello world')
print(char_counter) # Counter({'l': 3, 'o': 2, 'h': 1, 'e': 1, ' ': 1, 'w': 1, 'r': 1, 'd': 1})

# 手动计数
cnt = Counter()
cnt['a'] += 1
cnt['b'] += 2
print(cnt)          # Counter({'b': 2, 'a': 1})

4.2 常用方法

from collections import Counter

c = Counter('abracadabra')

# 获取元素(按频率排序)
print(list(c.elements()))  # ['a', 'a', 'a', 'a', 'a', 'b', 'b', 'r', 'r', 'c', 'd']

# 最常见的 n 个元素
print(c.most_common(2))    # [('a', 5), ('b', 2)]

# 获取计数(不存在返回 0,不报错)
print(c['z'])              # 0

# 更新计数器
c.update('abc')            # 添加新计数
print(c['a'])              # 6

# 减去
c.subtract('a')
print(c['a'])              # 5

# 算术运算
c1 = Counter('ab')
c2 = Counter('bc')
print(c1 + c2)             # Counter({'b': 2, 'a': 1, 'c': 1})
print(c1 - c2)             # Counter({'a': 1})
print(c1 & c2)             # 交集(取最小值): Counter({'b': 1})
print(c1 | c2)             # 并集(取最大值): Counter({'b': 1, 'a': 1, 'c': 1})

4.3 适用场景

  • • 统计词频
  • • 找出出现次数最多的元素
  • • 多集合运算
# 实战:分析文章词频
from collections import Counter
import re

defword_frequency(text):
    words = re.findall(r'\w+', text.lower())
return Counter(words)

text = "Python is great. Python is powerful. I love Python."
freq = word_frequency(text)
print(freq.most_common(3))  # [('python', 3), ('is', 2), ('great', 1)]

五、defaultdict——带默认值的字典

5.1 基本用法

defaultdict 在访问不存在的键时,不会抛出 KeyError,而是自动创建默认值。

from collections import defaultdict

# 使用 int 作为默认值(默认 0)
dd = defaultdict(int)
dd['a'] += 1
print(dd['a'])      # 1
print(dd['b'])      # 0(不存在,自动创建)

# 使用 list 作为默认值(默认 [])
dd_list = defaultdict(list)
dd_list['key'].append(1)
print(dd_list)      # defaultdict(<class 'list'>, {'key': [1]})

# 使用自定义默认值
defdefault_value():
return'N/A'

dd_custom = defaultdict(default_value)
print(dd_custom['name'])  # N/A

5.2 适用场景

  • • 分组统计
  • • 避免频繁的 if key not in dict 判断
# 实战:按首字母分组单词
from collections import defaultdict

words = ['apple''banana''cat''ant''bird''car']
grouped = defaultdict(list)

for word in words:
    grouped[word[0]].append(word)

print(dict(grouped))
# {'a': ['apple', 'ant'], 'b': ['banana', 'bird'], 'c': ['cat', 'car']}

六、OrderedDict——有序字典

6.1 基本用法

OrderedDict 会记住键的插入顺序。在 Python 3.7+ 中,普通 dict 也保持插入顺序,但 OrderedDict 提供了额外的有序操作。

from collections import OrderedDict

od = OrderedDict()
od['a'] = 1
od['b'] = 2
od['c'] = 3

for key, value in od.items():
print(key, value)   # 按插入顺序输出

# 移动元素
od.move_to_end('b')           # 移到末尾
od.move_to_end('a', last=False)  # 移到开头

# 弹出最后/最先
od.popitem()                  # 弹出最后
od.popitem(last=False)        # 弹出最先

6.2 适用场景

  • • 需要保持插入顺序的字典
  • • LRU 缓存实现
# 实战:简单 LRU 缓存
from collections import OrderedDict

classLRUCache:
def__init__(self, capacity):
self.cache = OrderedDict()
self.capacity = capacity

defget(self, key):
if key notinself.cache:
return -1
self.cache.move_to_end(key)
returnself.cache[key]

defput(self, key, value):
if key inself.cache:
self.cache.move_to_end(key)
self.cache[key] = value
iflen(self.cache) > self.capacity:
self.cache.popitem(last=False)

七、其他工具

7.1 ChainMap——合并多个映射

from collections import ChainMap

dict1 = {'a'1'b'2}
dict2 = {'b'3'c'4}

# 查找时按顺序查找,第一个匹配的优先
chain = ChainMap(dict1, dict2)
print(chain['a'])   # 1
print(chain['b'])   # 2(来自 dict1)
print(chain['c'])   # 4

# 修改会影响第一个字典
chain['b'] = 100
print(dict1['b'])   # 100

# 添加新映射
chain.new_child({'d'5})

7.2 UserDict、UserList、UserString

这些类用于创建自定义的字典、列表、字符串子类,比直接继承内置类型更方便。

from collections import UserDict

classMyDict(UserDict):
def__setitem__(self, key, value):
print(f"设置 {key} = {value}")
super().__setitem__(key, value)

d = MyDict()
d['a'] = 1# 设置 a = 1

八、性能对比

数据结构
头部插入/删除
尾部插入/删除
中间插入/删除
随机访问
list
O(n)
O(1)
O(n)
O(1)
deque
O(1)
O(1)
O(n)
O(n)
  • • 频繁头部操作 → 使用 deque
  • • 需要快速随机访问 → 使用 list
  • • 需要计数统计 → 使用 Counter
  • • 需要默认值 → 使用 defaultdict

九、实战案例

9.1 日志分析(Counter + defaultdict)

from collections import Counter, defaultdict
import re

log_data = """
192.168.1.1 - - [01/Jan/2025:10:00:00] "GET /index.html"
192.168.1.2 - - [01/Jan/2025:10:00:01] "GET /about.html"
192.168.1.1 - - [01/Jan/2025:10:00:02] "POST /login"
192.168.1.3 - - [01/Jan/2025:10:00:03] "GET /index.html"
192.168.1.1 - - [01/Jan/2025:10:00:04] "GET /index.html"
"""


# 统计 IP 访问次数
ip_pattern = r'(\d+\.\d+\.\d+\.\d+)'
ips = re.findall(ip_pattern, log_data)
ip_counter = Counter(ips)

print("IP 访问统计:")
for ip, count in ip_counter.most_common():
print(f"  {ip}{count}")

# 统计访问路径
path_pattern = r'"(?:GET|POST) (\S+)'
paths = re.findall(path_pattern, log_data)
path_counter = Counter(paths)

print("\n访问路径统计:")
for path, count in path_counter.most_common():
print(f"  {path}{count}")

9.2 任务调度(deque)

from collections import deque
import time
import threading

classTaskScheduler:
def__init__(self):
self.task_queue = deque()
self.running = True

defadd_task(self, task, delay=0):
self.task_queue.append((time.time() + delay, task))
# 按执行时间排序
self.task_queue = deque(sorted(self.task_queue, key=lambda x: x[0]))

defrun(self):
whileself.running andself.task_queue:
            execute_time, task = self.task_queue[0]
if time.time() >= execute_time:
self.task_queue.popleft()
                task()
else:
                time.sleep(0.1)

defstop(self):
self.running = False

defjob1():
print(f"[{time.strftime('%H:%M:%S')}] 执行任务1")

defjob2():
print(f"[{time.strftime('%H:%M:%S')}] 执行任务2")

scheduler = TaskScheduler()
scheduler.add_task(job1, 1)
scheduler.add_task(job2, 2)
# scheduler.run()

9.3 图形数据结构(namedtuple)

from collections import namedtuple

# 定义图形元素
Point = namedtuple('Point', ['x''y'])
Circle = namedtuple('Circle', ['center''radius'])
Rect = namedtuple('Rect', ['x''y''width''height'])

defarea(shape):
ifisinstance(shape, Circle):
return3.14159 * shape.radius ** 2
elifisinstance(shape, Rect):
return shape.width * shape.height
return0

# 使用
c = Circle(Point(00), 5)
r = Rect(001020)

print(f"圆面积: {area(c):.2f}")
print(f"矩形面积: {area(r)}")

十、总结

数据结构
主要用途
特性
namedtuple
轻量级数据类
不可变、可命名访问
deque
双端队列
两端高效操作
Counter
计数统计
自动统计、most_common
defaultdict
默认值字典
缺失键自动创建
OrderedDict
有序字典
保持插入顺序
ChainMap
多映射合并
链式查找

核心要点

  • • namedtuple 适合替代简单类,提高可读性。
  • • deque 用于队列和栈,特别是频繁的头部操作。
  • • Counter 是统计频率的最佳选择。
  • • defaultdict 简化分组和计数代码。
  • • Python 3.7+ 中 dict 已有序,OrderedDict 仍可用于需要 move_to_end 等操作的场景。

掌握 collections 模块,可以让你用更少的代码解决复杂的数据结构问题,写出更优雅、高效的 Python 代码。

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-07-04 18:22:35 HTTP/2.0 GET : https://f.mffb.com.cn/a/489882.html
  2. 运行时间 : 0.098225s [ 吞吐率:10.18req/s ] 内存消耗:4,959.88kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=afb0ee424b919707960db451798bf04e
  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.000553s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.000894s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.000358s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.000376s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.000494s ]
  6. SELECT * FROM `set` [ RunTime:0.000321s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.000640s ]
  8. SELECT * FROM `article` WHERE `id` = 489882 LIMIT 1 [ RunTime:0.000619s ]
  9. UPDATE `article` SET `lasttime` = 1783160555 WHERE `id` = 489882 [ RunTime:0.018206s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 66 LIMIT 1 [ RunTime:0.000273s ]
  11. SELECT * FROM `article` WHERE `id` < 489882 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.000704s ]
  12. SELECT * FROM `article` WHERE `id` > 489882 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.000412s ]
  13. SELECT * FROM `article` WHERE `id` < 489882 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.001156s ]
  14. SELECT * FROM `article` WHERE `id` < 489882 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.000854s ]
  15. SELECT * FROM `article` WHERE `id` < 489882 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.001552s ]
0.099848s