当前位置:首页>python>Python集合(set):数据去重与高效集合运算的必备利器

Python集合(set):数据去重与高效集合运算的必备利器

  • 2026-02-02 01:32:26
Python集合(set):数据去重与高效集合运算的必备利器

在Python开发中,你是否遇到过这些场景:需要快速去除列表中的重复数据?想要找出两个数据集的交集或差集?需要判断某个元素是否存在于大量数据中?这些问题的最优解答案都指向同一个数据结构——集合(set)

本文将深入剖析Python集合的核心特性,包括自动去重机制四大集合运算(并集、交集、差集、对称差集)以及无序特性的本质。通过丰富的代码实战案例,帮助你掌握这个在数据处理、算法优化中不可或缺的数据结构,让你的Python开发效率提升一个档次。

🔍 集合的本质:无序且唯一的数据容器

什么是集合?

集合(set)是Python内置的一种无序不重复的数据类型,底层基于哈希表实现。这意味着:

  1. 1. 元素唯一性:自动过滤重复元素
  2. 2. 无序性:不保证元素的存储顺序
  3. 3. 高效查询:成员检测速度极快(O(1)时间复杂度)
# 创建集合的三种方式# 创建集合的三种方式  set1 = {12345}  # 使用花括号  set2 = set([1223445])  # 从列表创建(自动去重)  set3 = set("hello")  # 从字符串创建  print(set1)  print(set2) print(set3)

⚠️ 重要特性说明

# 1. 集合元素必须是可哈希的(不可变类型)  valid_set = {1'python', (12), 3.14}  # ✅ 正确  # invalid_set = {[1, 2], {3, 4}}  # ❌ 错误:列表和集合不可哈希  # 2. 空集合必须用set()创建  empty_set = set()  # ✅ 正确  empty_dict = {}    # ❌ 这是空字典,不是空集合  # 3. 无序性演示  numbers = {51937}  print(numbers)

🎯 核心功能一:强大的去重能力

场景1:列表数据快速去重

在Windows应用开发中,处理用户日志、配置文件时经常需要去重:

# 用户访问日志中的IP地址去重ip_logs = [  '192.168.1.1''192.168.1.2''192.168.1.1',  '10.0.0.5''192.168.1.2''10.0.0.5']  # 方法1:转换为集合去重  unique_ips = list(set(ip_logs))  print(f"独立访客数量: {len(unique_ips)}")  # 3  print(unique_ips)  # 方法2:保留原始顺序的去重  unique_ips_ordered = list(dict.fromkeys(ip_logs))  print(unique_ips_ordered)

场景2:Excel数据处理中的去重

# 模拟从Excel读取的产品ID列表  product_ids = [  'SKU001''SKU002''SKU001''SKU003',  'SKU002''SKU004''SKU001''SKU003']  # 统计去重前后的数据量  print(f"原始记录数:  {len(product_ids)}"unique_products = set(product_ids)  print(f"去重后数量: {len(unique_products)}"print(f"重复记录数: {len(product_ids) - len(unique_products)}")

场景3:找出重复元素

deffind_duplicates(data_list):"""找出列表中的重复元素"""    seen = set()    duplicates = set()for item in data_list:if item in seen:            duplicates. add(item)else:            seen.add(item)return duplicates# 检测配置文件中的重复配置项config_keys = ['host''port''user''host''timeout''port']dup_keys = find_duplicates(config_keys)print(f"重复的配置项: {dup_keys}"

⚙️ 核心功能二:四大集合运算实战

1️⃣ 并集(Union):合并数据集

应用场景:合并多个来源的数据、用户权限合并

# 场景:两个部门的员工列表合并dept_a = {'张三''李四''王五'}dept_b = {'王五''赵六''孙七'}# 方法1:使用 | 运算符all_employees = dept_a | dept_bprint(all_employees) # 方法2:使用 union() 方法all_employees = dept_a.union(dept_b)# 多个集合并集dept_c = {'孙七''周八'}all_depts = dept_a | dept_b | dept_cprint(f"公司总人数: {len(all_depts)}"

2️⃣ 交集(Intersection):找出共同元素

应用场景:找出同时满足多个条件的数据、权限校验

# 场景:找出同时拥有两种权限的用户read_permission = {'user1''user2''user3''user4'}write_permission = {'user2''user3''user5''user6'}# 方法1:使用 & 运算符admin_users = read_permission & write_permissionprint(f"同时拥有读写权限的用户: {admin_users}")# 方法2:使用 intersection() 方法admin_users = read_permission. intersection(write_permission)# 实战案例:多条件筛选online_users = {'user1''user2''user3''user7'}active_last_month = {'user2''user3''user4''user5'}paid_users = {'user2''user3''user6'}# 找出在线且活跃且付费的用户(核心用户)core_users = online_users & active_last_month & paid_usersprint(f"核心用户: {core_users}"

3️⃣ 差集(Difference):找出独有元素

应用场景:数据对比、增量更新、权限移除

# 场景:找出需要新增的配置项old_config = {'host''port''user''password'}new_config = {'host''port''user''password''timeout''ssl'}# 方法1:使用 - 运算符added_items = new_config - old_configremoved_items = old_config - new_configprint(f"新增配置项: {added_items}")print(f"移除配置项: {removed_items}")# 方法2:使用 difference() 方法added_items = new_config.difference(old_config)# 实战:数据库同步场景db_records = {101102103104105}excel_records = {103104105106107}# 找出需要删除的记录(数据库有但Excel没有)to_delete = db_records - excel_recordsprint(f"需要删除的记录ID: {to_delete}")  # {101, 102}# 找出需要新增的记录(Excel有但数据库没有)to_insert = excel_records - db_recordsprint(f"需要新增的记录ID: {to_insert}")  # {106, 107}

4️⃣ 对称差集(Symmetric Difference):找出不共同的元素

应用场景:数据差异分析、异常检测

# 场景:找出两个数据源的差异项source_a = {'item1''item2''item3''item4'}source_b = {'item3''item4''item5''item6'}# 方法1:使用 ^ 运算符diff_items = source_a ^ source_bprint(f"差异项: {diff_items}")  # {'item1', 'item2', 'item5', 'item6'}# 方法2:使用 symmetric_difference() 方法diff_items = source_a. symmetric_difference(source_b)# 等价于:(A - B) | (B - A)diff_items_manual = (source_a - source_b) | (source_b - source_a)print(diff_items == diff_items_manual)  # True# 实战:文件对比工具file1_lines = set(['line1''line2''line3'])file2_lines = set(['line2''line3''line4'])different_lines = file1_lines ^ file2_linesprint(f"不同的行: {different_lines}")  # {'line1', 'line4'}

🔧 集合运算对比表

运算
符号
方法
说明
示例结果
并集
|union()
A或B中的所有元素
{1,2,3} | {3,4,5}
 → {1,2,3,4,5}
交集
&intersection()
A和B共有的元素
{1,2,3} & {3,4,5}
 → {3}
差集
-difference()
A有但B没有的元素
{1,2,3} - {3,4,5}
 → {1,2}
对称差
^symmetric_difference()
A和B不共有的元素
{1,2,3} ^ {3,4,5}
 → {1,2,4,5}

🚀 集合的高级操作

添加与删除元素

# 创建集合tags = {'python''django''flask'}# 1. add() - 添加单个元素tags.add('fastapi')print(tags)  # {'python', 'django', 'flask', 'fastapi'}# 添加已存在的元素(无效果)tags.add('python')print(tags)  # 仍然是4个元素# 2. update() - 批量添加(可接受任何可迭代对象)tags.update(['redis''mysql'])tags.update('go')  # 会拆分为 'g' 和 'o'print(tags)  # {'python', 'django', 'flask', 'fastapi', 'redis', 'mysql', 'g', 'o'}# 3. remove() - 删除元素(不存在会报错)tags.remove('g')# tags.remove('java')  # ❌ KeyError: 'java'# 4. discard() - 删除元素(不存在不报错)✅ 推荐tags.discard('o')tags.discard('java')  # 不会报错# 5. pop() - 随机删除并返回一个元素removed_tag = tags.pop()print(f"删除的标签: {removed_tag}")# 6. clear() - 清空集合tags.clear()print(tags)  # set()

集合判断方法

# 子集与超集判断basic_features = {'login''logout'}premium_features = {'login''logout''export''api'}# 1. issubset() - 判断是否为子集print(basic_features.issubset(premium_features))  # Trueprint(basic_features <= premium_features)  # True(等价写法)# 2. issuperset() - 判断是否为超集print(premium_features.issuperset(basic_features))  # Trueprint(premium_features >= basic_features)  # True# 3. isdisjoint() - 判断是否无交集free_features = {'view''search'}print(free_features.isdisjoint(premium_features))  # True(无共同元素)# 实战:权限校验defcheck_permission(user_permissions, required_permissions):"""检查用户是否拥有所需的所有权限"""return required_permissions.issubset(user_permissions)user_perms = {'read''write''delete'}required_perms = {'read''write'}if check_permission(user_perms, required_perms):print("权限验证通过!")else:print("权限不足!")

💡 无序特性的深入理解

为什么集合是无序的?

# 演示:集合的无序性numbers = {528193}print(numbers)  # 可能输出:{1, 2, 3, 5, 8, 9}(看起来有序,但不保证)# 多次创建同样的集合,顺序可能不同for _ inrange(3):    s = set([528193])print(list(s))  # 每次输出顺序可能不同

无序性的影响

# ❌ 错误示例:尝试使用索引访问fruits = {'apple''banana''orange'}# print(fruits[0])  # TypeError: 'set' object is not subscriptable# ✅ 正确做法:遍历集合for fruit in fruits: print(fruit)# 如果需要有序,转换为列表并排序sorted_fruits = sorted(fruits)print(sorted_fruits)  # ['apple', 'banana', 'orange']

🎮 实战案例:上位机数据采集场景

classDataCollector:"""模拟上位机数据采集器"""def__init__(self):self.collected_sensors = set()  # 已采集的传感器IDself.error_sensors = set()      # 故障传感器IDdefcollect_data(self, sensor_id):"""采集单个传感器数据"""self.collected_sensors.add(sensor_id)print(f"传感器 {sensor_id} 数据采集完成")defreport_error(self, sensor_id):"""报告传感器故障"""self.error_sensors.add(sensor_id)print(f"⚠️ 传感器 {sensor_id} 发生故障")defget_healthy_sensors(self):"""获取正常工作的传感器"""returnself.collected_sensors - self.error_sensorsdefget_status(self):"""获取采集状态"""        total = len(self.collected_sensors)        errors = len(self.error_sensors)        healthy = len(self.get_healthy_sensors())print(f"\n📊 采集状态统计")print(f"总传感器数: {total}")print(f"故障传感器:  {errors}")print(f"正常传感器: {healthy}")print(f"正常率: {healthy/total*100:.1f}%")# 使用示例collector = DataCollector()# 模拟数据采集for sensor_id inrange(111):    collector.collect_data(f"SENSOR_{sensor_id: 03d}")# 模拟故障上报collector.report_error("SENSOR_003")collector.report_error("SENSOR_007")# 查看状态collector.get_status()

输出结果:

⚡ 性能对比:集合 vs 列表

import time  # 准备测试数据  large_list = list(range(10000))  large_set = set(range(10000))  search_targets = [99950009999]  # 列表查找性能测试  start = time.time()  for target in search_targets * 10000:  if target in large_list:  passlist_time = time.time() - start  # 集合查找性能测试  start = time.time()  for target in search_targets * 10000:  if target in large_set:  passset_time = time.time() - start  print(f"列表查找耗时: {list_time:.4f}秒")  print(f"集合查找耗时: {set_time:.4f}秒")  print(f"集合速度提升: {list_time/set_time:.1f}倍")

性能结论:

  • • 成员检测:集合 O(1) vs 列表 O(n) → 集合快100+倍
  • • 去重操作set(list) 比循环判断快数十倍
  • • 集合运算:内置优化,远快于手动实现

🔥 最佳实践与注意事项

✅ 推荐做法

# 1. 使用集合进行成员检测allowed_users = {'admin''user1''user2'}if current_user in allowed_users:  # ✅ 快速    grant_access()# 2. 快速去重unique_items = list(set(items))  # ✅ 简洁高效# 3. 使用集合运算简化逻辑common_tags = set1 & set2  # ✅ 清晰易读# 4. 批量添加使用updatetags.update(['tag1''tag2''tag3'])  # ✅ 高效

❌ 避免做法

# 1. 不要用集合存储可变对象# bad_set = {[1, 2], {3, 4}}  # ❌ TypeError# 2. 不要依赖集合的顺序# first_item = list(my_set)[0]  # ❌ 不可预测# 3. 不要频繁转换类型for item inlist(my_set):  # ❌ 不必要的转换    process(item)# 应该直接遍历for item in my_set:  # ✅ 正确    process(item)

🎯 选择指南

场景
推荐数据结构
原因
需要去重
集合(set)
自动去重
需要保持顺序
列表(list)
有序
频繁查找元素
集合(set)
O(1)查找
需要索引访问
列表(list)
支持下标
集合运算
集合(set)
内置运算符
允许重复
列表(list)
可重复

🎓 总结与进阶

核心要点回顾

  1. 1. 集合的本质:基于哈希表的无序不重复容器,提供O(1)时间复杂度的成员检测
  2. 2. 四大集合运算
    • • 并集(|):合并数据
    • • 交集(&):找共同元素
    • • 差集(-):找独有元素
    • • 对称差(^):找不共同元素
  3. 3. 无序特性:不能依赖元素顺序,不支持索引访问,需要有序时转换为列表

实用技巧总结

  • • 数据去重首选 set(),比手动循环快数十倍
  • • 权限校验、标签匹配等场景优先使用集合运算
  • • 大数据量成员检测必用集合,性能提升百倍以上
  • • Windows应用开发中处理配置项、日志分析时灵活运用集合

延伸学习建议

  • • frozenset:不可变集合,可作为字典的键或集合的元素
  • • collections模块:Counter(计数器)、defaultdict等高级容器
  • • 算法应用:利用集合优化搜索算法、图论问题

掌握Python集合操作,不仅能让你的代码更简洁高效,更能在数据处理、上位机开发、算法优化等实际项目中游刃有余。从今天开始,把集合加入你的Python开发工具箱,让代码性能再上一个台阶!


💬 你在项目中是如何使用集合的?欢迎在评论区分享你的经验!

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-02-09 04:08:54 HTTP/2.0 GET : https://f.mffb.com.cn/a/460007.html
  2. 运行时间 : 0.162573s [ 吞吐率:6.15req/s ] 内存消耗:4,925.88kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=c60fb10776a131674e609417143c25df
  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.001061s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.001555s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.000706s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.000654s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.001282s ]
  6. SELECT * FROM `set` [ RunTime:0.000512s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.001440s ]
  8. SELECT * FROM `article` WHERE `id` = 460007 LIMIT 1 [ RunTime:0.001695s ]
  9. UPDATE `article` SET `lasttime` = 1770581334 WHERE `id` = 460007 [ RunTime:0.001567s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 66 LIMIT 1 [ RunTime:0.000594s ]
  11. SELECT * FROM `article` WHERE `id` < 460007 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.001245s ]
  12. SELECT * FROM `article` WHERE `id` > 460007 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.001056s ]
  13. SELECT * FROM `article` WHERE `id` < 460007 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.001972s ]
  14. SELECT * FROM `article` WHERE `id` < 460007 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.001518s ]
  15. SELECT * FROM `article` WHERE `id` < 460007 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.003402s ]
0.166519s