当前位置:首页>python>Python科研绘图:一行代码实现 R² + 95% 置信区间的高级散点图

Python科研绘图:一行代码实现 R² + 95% 置信区间的高级散点图

  • 2026-02-05 11:01:43
Python科研绘图:一行代码实现 R² + 95% 置信区间的高级散点图

01

前言

做过机器学习(ML)或深度学习的朋友,大抵都经历过这样的“至暗时刻”:你辛辛苦苦调参跑模型,得到了一个惊为天人的 R2=0.99,兴冲冲地把数字写进论文里。结果审稿人冷冷地回了一句:“Overfitting? Show me the distribution.”(过拟合了吧?给我看分布。)

是的,数字是苍白的,图表才是证据。

单纯列一个表格说“我的预测很准”,就像在相亲网上只写身高体重,远不如放一张无美颜的生活照有说服力。在科研论文中,Parity Plot(平价图/对角线图) 就是这张“无美颜生活照”。它把“真实值(Actual)”作为横轴,“预测值(Predicted)”作为纵轴——如果你的模型是完美的,所有点都会乖乖躺在 45° 对角线上。

今天我们要复刻的这张图,来自期刊 《Separation and Purification Technology》(中科院一区,IF=8.1)。作者用机器学习预测 MOF 材料的 SO2 和 CO2吸附量。这张图不仅展示了训练集和测试集的表现,还非常优雅地嵌入了统计指标、置信区间和分布密度。

今天,我就带大家用 Python 把这张图从骨架到灵魂,完整复刻一遍。我们要画的不仅仅是散点,而是你科研成果的“置信度”。

02

原图解析

在写代码之前,我们需要像外科医生一样,先对这张图进行“解剖”。很多同学画图不好看,不是因为代码写不对,而是因为没看懂原图的逻辑。

1. 视觉解剖 (The Anatomy)

一眼看过去,这张图是典型的 2x2 Panel 布局。但魔鬼都在细节里:

  • 🦴 骨架 (Structure):四个子图共享同一套逻辑,但量程(Scale)完全不同。注意看,为了视觉上的统一,作者强制让所有子图的 X 轴和 Y 轴保持 Isometric(等距) 比例,确保中间那条深红色的虚线(Bisect Line)严格呈现 45 度角。这是很多初学者容易忽视的点——如果比例不对,对角线歪了,读者的直觉判断就会失效。

  • 🍰 核心技巧 (The Trick) —— “三明治图层法”

    • 底层:淡蓝紫色背景 + 白色网格(Seaborn 的 darkgrid 风格),或者白底 + 灰色网格。

    • 夹层:对角参考线(一定要放在散点下面,zorder 很关键)。

    • 主菜:散点。注意,原图巧妙地用了 空心图形(Hollow Markers)。当数据点成千上万时,实心点会糊成一团,而空心点能透出叠加的密度感。

    • 顶层:拟合线 + 95% 置信区间阴影(Confidence Interval)。这层半透明的阴影是“高级感”的来源,它告诉读者:我的预测不仅准,而且很稳。

  • 🎨 配色 (Palette):原图使用了经典的 “红蓝CP” —— 蓝色代表训练集(Training),红色代表测试集(Testing)。这种对比色在学术界非常通用,色盲友好且对比强烈。

论文原图

2. 读懂神图 (Scientific Decoding)

别光顾着画,这图到底说了个啥?

如果你结合论文原文(Section 3.3),你会发现作者极其诚实。在 Panel (a) 预测 CO2 时,数据点紧紧“咬”住对角线,说明模型对二氧化碳吸附量的预测简直是“开了天眼”。但在 Panel (d) 预测 选择性(Selectivity) 时,测试集的数据点(红色圆圈)开始发散,尤其是在高值区域。

作者没有藏着掖着,而是把 R2、RMSE(均方根误差)甚至 p_{k-s}(残差正态性检验值)直接把这组数据“钉”在了图表角落。这种敢于暴露“不完美”的图,恰恰是审稿人最喜欢的——因为它真实。

我们要复刻的,就是这种“基于数据的诚实感”

03

代码复刻

Step 1 全局配置

Matplotlib 的默认字体(DejaVu Sans)在很多顶刊里是会被打回修改的。我们起手先注入“期刊基因”:Times New Roman 字体、向内的刻度、数学公式字体。

import matplotlib.pyplot as pltimport matplotlib.colors as mcolorsimport matplotlib.patches as mpatchesimport seaborn as snsimport numpy as npimport pandas as pdfrom scipy import stats# --- 全局审美配置 (The Aesthetics) ---# 这一步相当于给画布打底妆,决定了成图的高级感plt.rcParams['font.family'] = 'Times New Roman'  # 顶刊标配字体plt.rcParams['font.weight'] = 'bold'             # 稍微加粗更醒目plt.rcParams['axes.labelweight'] = 'bold'        # 轴标签加粗plt.rcParams['font.size'] = 14                   # 基础字号plt.rcParams['mathtext.fontset'] = 'stix'        # 公式字体,类似 LaTeX 质感plt.rcParams['axes.linewidth'] = 1.5             # 坐标轴线宽,拒绝细狗plt.rcParams['xtick.major.width'] = 1.5          # 刻度线宽plt.rcParams['ytick.major.width'] = 1.5# 定义一个类似于原图的“红-黄-蓝”配色方案# 注意:原图中间是黄色(0),两头是深色。这叫 Diverging Colormapcolors_list = ['#A50026''#F46D43''#FFFFBF''#74ADD1''#313695']custom_cmap = mcolors.LinearSegmentedColormap.from_list("Journal_Style", colors_list, N=256)

Step 2 数据模

为了演示 Panel (d) 那种“高值发散”的效果,我在生成数据时特意给 Testing 集加了更大的噪声。

def generate_mock_data(n_train=400, n_test=100):    """    生成模拟的 Predicted vs Actual 数据    """    np.random.seed(2024)    data = []    # 定义四个任务的量程和噪声水平    tasks = [        ('N_CO2'90.020.05),         # 简单任务        ('N_SO2'350.030.08),        # 中等        ('N_Sum'400.030.10),        # 稍难        ('Selectivity'400.040.15)   # 最难,发散严重    ]    for name, limit, noise_tr, noise_te in tasks:        # 训练集:噪声小        act_tr = np.random.uniform(0, limit, n_train)        pred_tr = act_tr + np.random.normal(0, noise_tr * limit, n_train)        # 测试集:噪声大(模拟泛化误差)        act_te = np.random.uniform(0, limit, n_test)        pred_te = act_te + np.random.normal(0, noise_te * limit, n_test)        # 封装        for a, p in zip(act_tr, pred_tr):            data.append({'Task': name, 'Group''Training''Actual': a, 'Predicted': p})        for a, p in zip(act_te, pred_te):            data.append({'Task': name, 'Group''Testing''Actual': a, 'Predicted': p})    return pd.DataFrame(data)df = generate_mock_data()

Step 3 画布构建

别再用 plt.subplots(2, 2) 这种偷懒写法了。使用 GridSpec 可以让你精确控制子图之间的间距(wspace/hspace),这对于多面板图的排版至关重要。

# 创建画布fig = plt.figure(figsize=(1210))# GridSpec 允许我们微调子图间距,tight_layout 往往不够完美gs = fig.add_gridspec(22, wspace=0.25, hspace=0.25)axes = [fig.add_subplot(gs[00]), fig.add_subplot(gs[01]),         fig.add_subplot(gs[10]), fig.add_subplot(gs[11])]task_names = ['N_CO2''N_SO2''N_Sum''Selectivity']limits = [9354040# 各图的坐标轴上限

Step 4 核心绘图循环

接下来的代码是整篇文章的精华。我们将遍历每一个子图,依次完成以下动作:

  1. 画对角线:这是基准。

  2. 画散点:区分训练/测试集。

  3. 画回归线:利用 sns.regplot 自动计算并绘制置信区间。

  4. 算指标:实时计算 $R^2$ 等统计量。

  5. 打标签:利用 transform=ax.transAxes 锁定文字位置。

for i, (ax, task, limit) in enumerate(zip(axes, task_names, limits)):    # 1. 绘制对角基准线 (Bisect Line)    # zorder=2 确保它在散点下面,linestyle='--' 虚线不抢戏    ax.plot([0limit], [0limit], color='maroon', linestyle='--', linewidth=2, label='Bisect', zorder=2)    # 2. 分组绘制数据    subset = df[df['Task'] == task]    for group in ['Training''Testing']:        data = subset[subset['Group'] == group]        style = STYLE_CONFIG[group]        # [核心技巧] 散点绘制        # c='none' + edgecolors 控制空心圆,alpha 控制透明度        ax.scatter(data['Actual'], data['Predicted'],                    c='none', edgecolors=style['color'], marker=style['marker'],                    s=60, linewidth=1.2, alpha=0.7, label=style['label'], zorder=5)        # [核心技巧] Seaborn 统计回归线        # ci=95 自动画出95%置信区间,scatter=False 避免重复画点        sns.regplot(x='Actual', y='Predicted'data=data, ax=ax,                    scatter=False, color=style['color'], ci=95                    line_kws={'linewidth'2'alpha'0.8}, truncate=False)        # 3. 实时计算统计指标        r2 = r2_score(data['Actual'], data['Predicted'])        rmse = np.sqrt(mean_squared_error(data['Actual'], data['Predicted']))        # 4. 动态生成统计文本框 (The Soul Injection)        # 训练集放左上,测试集放右下        # 关键参数:bbox 给文字加个半透明背景,防止被散点挡住看不清!        stats_text = (f"{group}\n"                      f"$\mathbf{{R^2: {r2:.2f}}}$\n"                      f"RMSE: {rmse:.2f}")        pos = (0.050.95if group == 'Training'else (0.950.05)        align = ('left''top'if group == 'Training'else ('right''bottom')        ax.text(pos[0], pos[1], stats_text, transform=ax.transAxes,                fontsize=12, fontweight='bold', color=style['color'],                ha=align[0], va=align[1], zorder=10,                bbox=dict(facecolor='white', alpha=0.6, edgecolor='none', boxstyle='round,pad=0.5'))    # 5. 装饰与美化    ax.set_xlim(0, limit); ax.set_ylim(0, limit)    ax.set_xlabel(f"Actual {task}", fontweight='bold')    ax.set_ylabel(f"Predicted {task}", fontweight='bold')    # 给子图打标号 (a, b, c, d)    ax.text(-0.151.05, ['a''b''c''d'][i], transform=ax.transAxes,             fontsize=20, fontweight='bold', va='top', ha='right')    # 只有第一个图显示图例,避免冗余    if i == 0:        ax.legend(loc='upper center', bbox_to_anchor=(0.51.15), ncol=3, frameon=False)# 保存图片plt.savefig('Parity_Plot_Review.png', dpi=300, bbox_inches='tight')plt.show()

复刻图

技术总结 (Takeaway):

  1. 坐标系一致性:Parity Plot 的 X/Y 轴量程必须一致,否则 45 度线就没有物理意义。

  2. Seaborn 的威力:用 sns.regplot 代替手写的 polyfit,不仅能画线,还能自动补齐置信区间(Shadow Band),这是提升图表“高级感”的捷径。

  3. 相对坐标引用transform=ax.transAxes 是制作通用绘图模板的神器。无论你的数据范围是 0.1 还是 10000,(0.05, 0.95) 永远指向左上角。

04

多配色参考

多配色参考

05

代码获取

👇 关注公众号【嗡嗡的Python日常】

🚫 关于源码: 本文核心代码为原创定制,暂不免费公开。

✅ 如果你需要:

  • 购买本项目完整源码 + 数据

  • 定制类似的科研绘图

  • 咨询代码运行报错问题

请直接添加号主微信沟通(有偿分享☕️): Wjtaiztt0406

微信号丨Wjtaiztt0406

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-02-08 21:44:26 HTTP/2.0 GET : https://f.mffb.com.cn/a/461154.html
  2. 运行时间 : 0.178699s [ 吞吐率:5.60req/s ] 内存消耗:4,605.88kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=19de676c5b509089c76cb40ea239fd7c
  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.000824s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.001617s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.000706s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.005096s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.001426s ]
  6. SELECT * FROM `set` [ RunTime:0.000862s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.001549s ]
  8. SELECT * FROM `article` WHERE `id` = 461154 LIMIT 1 [ RunTime:0.006399s ]
  9. UPDATE `article` SET `lasttime` = 1770558266 WHERE `id` = 461154 [ RunTime:0.012049s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 66 LIMIT 1 [ RunTime:0.002796s ]
  11. SELECT * FROM `article` WHERE `id` < 461154 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.018897s ]
  12. SELECT * FROM `article` WHERE `id` > 461154 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.002719s ]
  13. SELECT * FROM `article` WHERE `id` < 461154 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.019853s ]
  14. SELECT * FROM `article` WHERE `id` < 461154 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.007151s ]
  15. SELECT * FROM `article` WHERE `id` < 461154 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.012167s ]
0.183492s