当前位置:首页>python>Python 可视化进阶:手撸 SHAP 蜂巢图 + 混合相关性热图组合面板

Python 可视化进阶:手撸 SHAP 蜂巢图 + 混合相关性热图组合面板

  • 2026-02-26 00:58:06
Python 可视化进阶:手撸 SHAP 蜂巢图 + 混合相关性热图组合面板

!

参考文章

📜 论文标题:Analysis of spatiotemporal variations and driving mechanisms of ecosystem health in arid oasis urban agglomerations using machine learning

📆 发表时间:2026 年

🔗 DOI:10.1016/j.ecolind.2025.114504

上图主要由两部分组成,分别用于展示影响因子的重要性和相互关系,绘图思路和核心元素如下:

1. 左侧:SHAP 重要性条形图与蜂巢图结合

  • 绘图目的:展示各因子对因变量的重要性及影响方向。

  • 核心元素:

  • Y 轴:列出所有影响因子(如 temp、sand、pre 等)。

  • X 轴:SHAP 值,代表该因子对模型输出的影响程度。

  • 条形长度:表示平均 SHAP 值(Mean |SHAP| value),条形越长,因子越重要。

  • 颜色渐变:从蓝色(低特征值)到红色(高特征值),展示不同特征水平下的 SHAP 值分布。

  • 百分比标注:每个因子后标注了其贡献度(如 36.79%),量化其相对重要性。

2. 右侧:相关性热力图(Correlation Heatmap)

  • 绘图目的:展示各影响因子之间的线性相关关系。

  • 核心元素:

  • 红色:正相关(相关系数 > 0),颜色越深,正相关越强。

  • 蓝色:负相关(相关系数 < 0),颜色越深,负相关越强。

  • 白色:相关系数接近 0。

  • 矩阵结构:行和列均为相同的影响因子,形成对称矩阵。

  • 颜色编码:

  • 数值标注:每个单元格内标注了相关系数(如 0.99、-0.85),精确量化相关性强度。

  • 对角线:均为 1,表示因子与自身完全相关。

01

!

左侧:SHAP 重要性条形图与蜂巢图结合

在机器学习模型解释性分析中, SHAP (SHapley Additive exPlanations) 无疑是目前的黄金标准。

通常我们在使用 shap.summary_plot 时,面临一个选择困难:

- Dot plot(蜂巢图) :虽然能展示特征值高低对预测结果的正负影响分布,但很难一眼看出特征重要性的具体数值差异。

- Bar plot(条形图) :能清晰地按重要性排序并显示数值,但丢掉了样本分布的细节信息。

- 双轴设计 :底部 X 轴展示具体的 SHAP 值分布(正负影响),顶部 X 轴展示平均绝对 SHAP 值(整体重要性)。

- 图层叠加 :利用 twiny() 共享 Y 轴。粉色的重要性条形图作为 半透明背景 显示,既不喧宾夺主,又能清晰展示长度差异;蜂巢散点图覆盖在上层,保留交互感。

- 数据可视化增强 :在每个条形图的起始位置,自动计算并标注了具体的 重要性数值 和 百分比贡献 ,让图表的信息密度直接拉满。

- 对称美学 :底部 X 轴自动以 0 为中心对称,方便观察正负向影响的平衡性。

-使用小提琴图代替蜂巢图,小提琴图和蜂巢图的区别如下:

  • 小提琴图:在同一坐标系下,所有特征的分布、重要性和影响方向都能同时展示,便于快速对比。

  • 蜂巢图:当特征数量较多时,布局会变得复杂,难以在同一视图下高效对比多个特征的 SHAP 行为。

import numpy as npfrom matplotlib.ticker import FormatStrFormatter# 创建主图(用来画蜂巢图)fig, ax1 = plt.subplots(figsize=(10.54.8), dpi=1200)max_display = min(20len(columns))# 先画蜂巢图(底部 x 轴:SHAP value)plt.sca(ax1)shap.summary_plot(    shap_values_test,    X_test,    feature_names=columns,    plot_type="violin",    max_display=max_display,    show=False,    color_bar=True,)ax1 = plt.gca()ax1.set_position([0.240.180.600.72])_xmin, _xmax = ax1.get_xlim()_m_data = max(abs(_xmin), abs(_xmax))if np.isfinite(_m_data) and _m_data > 0:    _m_tick = _m_data    _m_lim = _m_tick * 1.12    ax1.set_xlim(-_m_lim, _m_lim)    ax1.set_xticks([-_m_tick, -_m_tick / 2.00.0, _m_tick / 2.0, _m_tick])    ax1.xaxis.set_major_formatter(FormatStrFormatter("%.2f"))_bee_y_ticks = ax1.get_yticks()_bee_y_labels = [t.get_text() for t in ax1.get_yticklabels()]# 顶部 x 轴:Mean(|SHAP|) 的条形图(与蜂巢图共享 y 轴)ax2 = ax1.twiny()ax2.set_position(ax1.get_position())plt.sca(ax2)shap.summary_plot(    shap_values_test,    X_test,    feature_names=columns,    plot_type="bar",    max_display=max_display,    show=False,    color_bar=False,)# 让条形图作为背景显示,蜂巢图盖在上面ax2.set_ylim(ax1.get_ylim())ax2.set_yticks([])ax2.set_ylabel("")for bar in ax2.patches:    bar.set_facecolor("#f2a7b5")    bar.set_alpha(0.35)    bar.set_edgecolor("none")    bar.set_linewidth(0)ax2.set_zorder(0)ax1.set_zorder(1)ax1.patch.set_visible(False)# 在每个条形起点标注 mean(|SHAP|) 和百分比if hasattr(shap_values_test, "values"):    _sv = np.asarray(shap_values_test.values)else:    _sv = np.asarray(shap_values_test)_mean_abs_all = np.mean(np.abs(_sv), axis=0)_total = float(np.sum(_mean_abs_all)) if np.isfinite(np.sum(_mean_abs_all)) else 0.0_order = np.argsort(_mean_abs_all)[::-1][:max_display]_mean_abs_top = _mean_abs_all[_order]_total_top = float(np.sum(_mean_abs_top)) if np.isfinite(np.sum(_mean_abs_top)) else 0.0if len(_bee_y_labels) > 0:    ax1.set_yticks(_bee_y_ticks)    ax1.set_yticklabels(_bee_y_labels)_x_min, _x_max = ax2.get_xlim()_x0 = 0.0 if (_x_min <= 0.0 <= _x_max) else _x_min_x_text = _x0 + 0.01 * (_x_max - _x_min)_bars_sorted = sorted(    ax2.patches,    key=lambda b: (b.get_y() + b.get_height() / 2.0),    reverse=True,)_n = min(len(_bars_sorted), len(_mean_abs_top))for i in range(_n):    bar = _bars_sorted[i]    _y = bar.get_y() + bar.get_height() / 2.0    _v = float(_mean_abs_top[i])    _pct = (100.0 * _v / _total_top) if _total_top > 0 else 0.0    ax2.text(        _x_text,        _y,        f"{_v:.3f}({_pct:.2f}%)",        va="center",        ha="left",        fontsize=9,        color="black",        zorder=3,    )# 四边框与左侧刻度线(让特征名称更像示例图)for spine in ["top""right""bottom""left"]:    ax1.spines[spine].set_visible(True)    ax1.spines[spine].set_linewidth(1.0)ax1.tick_params(axis="y", which="major", length=6, direction="out")ax1.yaxis.grid(True, linestyle=":", linewidth=0.6, alpha=0.4)ax1.set_axisbelow(True)# 轴标签与刻度位置(尽量贴近示例图)ax1.set_xlabel("SHAP value (impact on model output)", fontsize=12)ax1.set_ylabel("")ax2.set_xlabel("Mean (|SHAP| value)", fontsize=12)ax2.xaxis.set_label_position("top")ax2.xaxis.tick_top()plt.savefig("SHAP蜂巢图加重要性.png", dpi=800, bbox_inches="tight")plt.show()

当然也可以换成蜂巢图或者更换颜色分布,分别通过

plot_type和cmap两个参数进行设置。

import numpy as npfrom matplotlib.ticker import FormatStrFormatter# 创建主图(用来画蜂巢图)fig, ax1 = plt.subplots(figsize=(10.54.8), dpi=1200)max_display = min(20len(columns))# 先画蜂巢图(底部 x 轴:SHAP value)plt.sca(ax1)shap.summary_plot(    shap_values_test,    X_test,    feature_names=columns,    plot_type="dot",    max_display=max_display,    show=False,    color_bar=True,)ax1 = plt.gca()ax1.set_position([0.240.180.600.72])_xmin, _xmax = ax1.get_xlim()_m_data = max(abs(_xmin), abs(_xmax))if np.isfinite(_m_data) and _m_data > 0:    _m_tick = _m_data    _m_lim = _m_tick * 1.12    ax1.set_xlim(-_m_lim, _m_lim)    ax1.set_xticks([-_m_tick, -_m_tick / 2.00.0, _m_tick / 2.0, _m_tick])    ax1.xaxis.set_major_formatter(FormatStrFormatter("%.2f"))_bee_y_ticks = ax1.get_yticks()_bee_y_labels = [t.get_text() for t in ax1.get_yticklabels()]# 顶部 x 轴:Mean(|SHAP|) 的条形图(与蜂巢图共享 y 轴)ax2 = ax1.twiny()ax2.set_position(ax1.get_position())plt.sca(ax2)shap.summary_plot(    shap_values_test,    X_test,    feature_names=columns,    plot_type="bar",    max_display=max_display,    show=False,    color_bar=False,)# 让条形图作为背景显示,蜂巢图盖在上面ax2.set_ylim(ax1.get_ylim())ax2.set_yticks([])ax2.set_ylabel("")for bar in ax2.patches:    bar.set_facecolor("#f2a7b5")    bar.set_alpha(0.35)    bar.set_edgecolor("none")    bar.set_linewidth(0)ax2.set_zorder(0)ax1.set_zorder(1)ax1.patch.set_visible(False)# 在每个条形起点标注 mean(|SHAP|) 和百分比if hasattr(shap_values_test, "values"):    _sv = np.asarray(shap_values_test.values)else:    _sv = np.asarray(shap_values_test)_mean_abs_all = np.mean(np.abs(_sv), axis=0)_total = float(np.sum(_mean_abs_all)) if np.isfinite(np.sum(_mean_abs_all)) else 0.0_order = np.argsort(_mean_abs_all)[::-1][:max_display]_mean_abs_top = _mean_abs_all[_order]_total_top = float(np.sum(_mean_abs_top)) if np.isfinite(np.sum(_mean_abs_top)) else 0.0if len(_bee_y_labels) > 0:    ax1.set_yticks(_bee_y_ticks)    ax1.set_yticklabels(_bee_y_labels)_x_min, _x_max = ax2.get_xlim()_x0 = 0.0 if (_x_min <= 0.0 <= _x_max) else _x_min_x_text = _x0 + 0.01 * (_x_max - _x_min)_bars_sorted = sorted(    ax2.patches,    key=lambda b: (b.get_y() + b.get_height() / 2.0),    reverse=True,)_n = min(len(_bars_sorted), len(_mean_abs_top))for i in range(_n):    bar = _bars_sorted[i]    _y = bar.get_y() + bar.get_height() / 2.0    _v = float(_mean_abs_top[i])    _pct = (100.0 * _v / _total_top) if _total_top > 0 else 0.0    ax2.text(        _x_text,        _y,        f"{_v:.3f}({_pct:.2f}%)",        va="center",        ha="left",        fontsize=9,        color="black",        zorder=3,    )# 四边框与左侧刻度线(让特征名称更像示例图)for spine in ["top""right""bottom""left"]:    ax1.spines[spine].set_visible(True)    ax1.spines[spine].set_linewidth(1.0)ax1.tick_params(axis="y", which="major", length=6, direction="out")ax1.yaxis.grid(True, linestyle=":", linewidth=0.6, alpha=0.4)ax1.set_axisbelow(True)# 轴标签与刻度位置(尽量贴近示例图)ax1.set_xlabel("SHAP value (impact on model output)", fontsize=12)ax1.set_ylabel("")ax2.set_xlabel("Mean (|SHAP| value)", fontsize=12)ax2.xaxis.set_label_position("top")ax2.xaxis.tick_top()plt.savefig("SHAP蜂巢图加重要性1.png", dpi=800, bbox_inches="tight")plt.show()

02

!

2. 右侧:相关性热力图(Correlation Heatmap)

- 左下角 :直接展示 相关系数数值 。不再只是冷冰冰的数字,数字颜色会随着相关性的强弱和正负发生渐变(红正蓝负),与右侧图例完美呼应。

- 右上角 :这是最精彩的部分—— 动态扇形(Pie Chart)可视化 。

1. 填充面积 = 相关性强度

   - ∣ r ∣ ≈ 1 :强相关。扇形几乎填满整个圆,视觉冲击力最强。

   - ∣ r ∣ ≈ 0 :无相关。扇形面积极小甚至消失,留白更多。

   - 一眼看去 :圆越满,关系越铁;圆越空,关系越淡。

2. 填充方向 = 相关性正负

   - 所有的扇形都以 12点钟方向 (正上方)为同一起跑线。

   - 正相关 (  r > 0 ) :扇形向 右 (顺时针)展开,寓意“正向增长”。

   - 负相关 (  r < 0 ) :扇形向 左 (逆时针)展开,寓意“反向背离”。

这种设计利用了人类对几何图形的直觉敏感度,比单纯比对颜色深浅要快得多,也能瞬间分清正负关系。

3. 显著性标记

   - 图表中还贴心地叠加了星号(***),直接标出 p 值显著性水平,做学术汇报必备!

import pandas as pdimport numpy as npimport shapimport matplotlib.pyplot as pltfrom matplotlib.colors import Normalize, LinearSegmentedColormapfrom sklearn.model_selection import train_test_split, GridSearchCVfrom sklearn.neural_network import MLPClassifierfrom sklearn.svm import SVCfrom sklearn.linear_model import LogisticRegressionfrom sklearn.neighbors import KNeighborsClassifierfrom sklearn.tree import DecisionTreeClassifierfrom sklearn.ensemble import RandomForestClassifierdata=pd.read_csv('diabetes.csv')X=data.iloc[:,:-1].valuescolumns=data.columns[:-1].valuesy=data.iloc[:,-1].valuesfrom matplotlib.cm import ScalarMappablefrom matplotlib.patches import Circle, Wedgetry:    from scipy.stats import pearsonrexcept Exception:    pearsonr = Nonedef pearson_corr_heatmap_mixed(x, feature_names, save_path=None, dpi=300):    df = pd.DataFrame(x, columns=feature_names)    corr = df.corr(method="pearson").values    n = corr.shape[0]    pvals = None    if pearsonr is not None:        pvals = np.ones((n, n), dtype=float)        for i in range(n):            for j in range(n):                if i == j:                    pvals[i, j] = 0.0                else:                    _, pvals[i, j] = pearsonr(df.iloc[:, i].values, df.iloc[:, j].values)    norm = Normalize(vmin=-1, vmax=1)    cmap = LinearSegmentedColormap.from_list(        "red_purple_blue",        ["#1e88e5""#8e24aa""#ff1744"],        N=256,    )    fig, ax = plt.subplots(figsize=(8.06.5), dpi=dpi)    ax.set_xlim(-0.5, n - 0.5)    ax.set_ylim(n - 0.5, -0.5)    ax.set_aspect("equal")    for k in range(n + 1):        ax.plot([-0.5, n - 0.5], [k - 0.5, k - 0.5], color="#cfcfcf", lw=1)        ax.plot([k - 0.5, k - 0.5], [-0.5, n - 0.5], color="#cfcfcf", lw=1)    r_cell = 0.42    for i in range(n):        for j in range(n):            r = float(corr[i, j])            x0, y0 = j, i            if i == j:                ax.text(                    x0,                    y0,                    feature_names[i],                    ha="center",                    va="center",                    fontsize=14,                    color="#333333",                )                continue            if i > j:                ax.text(                    x0,                    y0,                    f"{r:.2f}",                    ha="center",                    va="center",                    fontsize=12,                    color=cmap(norm(r)),                    fontweight="bold",                )                continue            circ = Circle((x0, y0), r_cell, facecolor="white", edgecolor="black", lw=1)            ax.add_patch(circ)            theta = 360.0 * abs(r)            if theta > 0:                start = -90.0                if r >= 0:                    theta1, theta2 = start - theta, start                else:                    theta1, theta2 = start, start + theta                wedge = Wedge(                    (x0, y0),                    r_cell,                    theta1=theta1,                    theta2=theta2,                    facecolor=cmap(norm(r)),                    edgecolor="none",                )                ax.add_patch(wedge)            if pvals is not None:                p = float(pvals[i, j])                stars = ""                if p < 0.001:                    stars = "***"                elif p < 0.01:                    stars = "**"                elif p < 0.05:                    stars = "*"                if stars:                    ax.text(                        x0,                        y0,                        stars,                        ha="center",                        va="center",                        fontsize=12,                        color="#222222",                    )    ax.set_xticks([])    ax.set_yticks([])    for spine in ["top""right""bottom""left"]:        ax.spines[spine].set_visible(False)    sm = ScalarMappable(norm=norm, cmap=cmap)    sm.set_array([])    cbar = fig.colorbar(sm, ax=ax, fraction=0.046, pad=0.04)    cbar.set_ticks([-1, -0.500.51])    fig.tight_layout()    if save_path:        fig.savefig(save_path, dpi=dpi, bbox_inches="tight")    return fig, axfeature_names = [f"X{i + 1}" for i in range(X.shape[1])]pearson_corr_heatmap_mixed(X, feature_names, save_path="Pearson相关性热图.png", dpi=600)plt.show()

3

!

组合图

这张图采用了 横向双面板布局 ,信息量极大但逻辑清晰:

左侧面板:SHAP 蜂巢图 + 重要性条形图

这是对模型预测逻辑的深度解剖:

- 特征排序 :自上而下,特征重要性递减,一眼锁定关键因子。

- 红蓝蜂巢 :展示特征值(红高蓝低)对模型输出的正负影响。

- 粉色背景条 :量化展示平均绝对 SHAP 值 (Mean |SHAP|),并直接标注了 具体的贡献数值和百分比 ,让定性分析瞬间变成定量分析。 

右侧面板:混合型 Pearson 相关性热图

这是对特征内部关系的全面体检:

- 数值+几何双显 :左下角直接看相关系数数值(颜色渐变),右上角看扇形面积(大小代表强度,方向代表正负)。

- 特征映射 :为了保持图表整洁,右图使用 X 1 , X 2... 代号,并在底部贴心地附上了与原始特征名的对照表。

import numpy as npimport pandas as pdimport shapimport matplotlib.pyplot as pltfrom matplotlib.cm import ScalarMappablefrom matplotlib.colors import Normalize, LinearSegmentedColormapfrom matplotlib.patches import Circle, Wedgefrom matplotlib.ticker import FormatStrFormattertry:    from scipy.stats import pearsonrexcept Exception:    pearsonr = Nonecolumns=['Pregnancies''Glucose''Blood''Skin',       'Insulin''BMI''Diab''Age']def pearson_corr_heatmap_mixed(ax, fig, x, feature_names, cmap, norm, cbar_pos, start_angle=-90.0):    df = pd.DataFrame(x, columns=feature_names)    corr = df.corr(method="pearson").to_numpy()    n = corr.shape[0]    pvals = None    if pearsonr is not None:        pvals = np.ones((n, n), dtype=float)        for i in range(n):            xi = df.iloc[:, i].to_numpy()            for j in range(n):                if i == j:                    pvals[i, j] = 0.0                else:                    _, pvals[i, j] = pearsonr(xi, df.iloc[:, j].to_numpy())    ax.set_xlim(-0.5, n - 0.5)    ax.set_ylim(n - 0.5, -0.5)    ax.set_aspect("equal")    for k in range(n + 1):        ax.plot([-0.5, n - 0.5], [k - 0.5, k - 0.5], color="#cfcfcf", lw=1)        ax.plot([k - 0.5, k - 0.5], [-0.5, n - 0.5], color="#cfcfcf", lw=1)    r_cell = 0.42    for i in range(n):        for j in range(n):            r = float(corr[i, j])            x0, y0 = j, i            if i == j:                ax.text(x0, y0, feature_names[i], ha="center", va="center", fontsize=14, color="#333333")                continue            if i > j:                ax.text(x0, y0, f"{r:.2f}", ha="center", va="center", fontsize=12, color=cmap(norm(r)), fontweight="bold")                continue            ax.add_patch(Circle((x0, y0), r_cell, facecolor="white", edgecolor="black", lw=1))            theta = 360.0 * abs(r)            if theta > 0:                start = float(start_angle)                if r >= 0:                    theta1, theta2 = start - theta, start                else:                    theta1, theta2 = start, start + theta                ax.add_patch(Wedge((x0, y0), r_cell, theta1=theta1, theta2=theta2, facecolor=cmap(norm(r)), edgecolor="none"))            if pvals is not None:                p = float(pvals[i, j])                stars = "***" if p < 0.001 else "**" if p < 0.01 else "*" if p < 0.05 else ""                if stars:                    ax.text(x0, y0, stars, ha="center", va="center", fontsize=12, color="#222222")    ax.set_xticks([])    ax.set_yticks([])    for spine in ["top""right""bottom""left"]:        ax.spines[spine].set_visible(False)    cax = fig.add_axes(cbar_pos)    sm = ScalarMappable(norm=norm, cmap=cmap)    sm.set_array([])    cbar = fig.colorbar(sm, cax=cax)    cbar.set_ticks([-1, -0.500.51])fig = plt.figure(figsize=(185), dpi=1200)max_display = min(20len(columns))_left_bee = [0.060.180.360.72]_left_cb = [0.430.180.0120.72]_right_corr = [0.520.180.40.72]_right_cb = [0.950.180.0150.72]ax1 = fig.add_axes(_left_bee)# 先画蜂巢图(底部 x 轴:SHAP value)plt.sca(ax1)shap.summary_plot(    shap_values_test,    X_test,    feature_names=columns,    plot_type="violin",    max_display=max_display,    show=False,    color_bar=True,)ax1 = plt.gca()ax1.set_position(_left_bee)fig.canvas.draw()_cb_ax = Nonefor _a in fig.axes:    if _a is not ax1 and _a.get_ylabel() == "Feature value":        _cb_ax = _a        breakif _cb_ax is not None:    _cb_ax.set_position(_left_cb)_xmin, _xmax = ax1.get_xlim()_m_data = max(abs(_xmin), abs(_xmax))if np.isfinite(_m_data) and _m_data > 0:    _m_tick = _m_data    _m_lim = _m_tick * 1.12    ax1.set_xlim(-_m_lim, _m_lim)    ax1.set_xticks([-_m_tick, -_m_tick / 2.00.0, _m_tick / 2.0, _m_tick])    ax1.xaxis.set_major_formatter(FormatStrFormatter("%.2f"))_bee_y_ticks = ax1.get_yticks()_bee_y_labels = [t.get_text() for t in ax1.get_yticklabels()]if not any(_bee_y_labels):    fig.canvas.draw()    _bee_y_ticks = ax1.get_yticks()    _bee_y_labels = [t.get_text() for t in ax1.get_yticklabels()]# 顶部 x 轴:Mean(|SHAP|) 的条形图(与蜂巢图共享 y 轴)ax2 = ax1.twiny()ax2.set_position(ax1.get_position())plt.sca(ax2)shap.summary_plot(    shap_values_test,    X_test,    feature_names=columns,    plot_type="bar",    max_display=max_display,    show=False,    color_bar=False,)# 让条形图作为背景显示,蜂巢图盖在上面ax2.set_ylim(ax1.get_ylim())ax2.set_yticks([])ax2.set_ylabel("")for bar in ax2.patches:    bar.set_facecolor("#f2a7b5")    bar.set_alpha(0.35)    bar.set_edgecolor("none")    bar.set_linewidth(0)ax2.set_zorder(0)ax1.set_zorder(1)ax1.patch.set_visible(False)# 在每个条形起点标注 mean(|SHAP|) 和百分比if hasattr(shap_values_test, "values"):    _sv = np.asarray(shap_values_test.values)else:    _sv = np.asarray(shap_values_test)_mean_abs_all = np.mean(np.abs(_sv), axis=0)_total = float(np.sum(_mean_abs_all)) if np.isfinite(np.sum(_mean_abs_all)) else 0.0_order = np.argsort(_mean_abs_all)[::-1][:max_display]_mean_abs_top = _mean_abs_all[_order]_total_top = float(np.sum(_mean_abs_top)) if np.isfinite(np.sum(_mean_abs_top)) else 0.0if len(_bee_y_labels) > 0:    ax1.set_yticks(_bee_y_ticks)    ax1.set_yticklabels(_bee_y_labels)_x_min, _x_max = ax2.get_xlim()_x0 = 0.0 if (_x_min <= 0.0 <= _x_max) else _x_min_x_text = _x0 + 0.01 * (_x_max - _x_min)_bars_sorted = sorted(    ax2.patches,    key=lambda b: (b.get_y() + b.get_height() / 2.0),    reverse=True,)_n = min(len(_bars_sorted), len(_mean_abs_top))for i in range(_n):    bar = _bars_sorted[i]    _y = bar.get_y() + bar.get_height() / 2.0    _v = float(_mean_abs_top[i])    _pct = (100.0 * _v / _total_top) if _total_top > 0 else 0.0    ax2.text(        _x_text,        _y,        f"{_v:.3f}({_pct:.2f}%)",        va="center",        ha="left",        fontsize=9,        color="black",        zorder=3,    )# 四边框与左侧刻度线(让特征名称更像示例图)for spine in ["top""right""bottom""left"]:    ax1.spines[spine].set_visible(True)    ax1.spines[spine].set_linewidth(1.0)ax1.tick_params(    axis="y",    which="major",    left=True,    labelleft=True,    length=8,    width=1.0,    direction="out",    pad=4,)ax1.yaxis.grid(True, linestyle=":", linewidth=0.6, alpha=0.4)ax1.set_axisbelow(True)# 轴标签与刻度位置(尽量贴近示例图)ax1.set_xlabel("SHAP value (impact on model output)", fontsize=12)ax1.set_ylabel("")ax2.set_xlabel("Mean (|SHAP| value)", fontsize=12)ax2.xaxis.set_label_position("top")ax2.xaxis.tick_top()ax_corr = fig.add_axes(_right_corr)try:    _X_corr = Xexcept NameError:    _X_corr = X_test_feature_names = [f"X{i + 1}" for i in range(_X_corr.shape[1])]_norm = Normalize(vmin=-1, vmax=1)_cmap = LinearSegmentedColormap.from_list(    "red_purple_blue",    ["#1e88e5""#8e24aa""#ff1744"],    N=256,)pearson_corr_heatmap_mixed(ax_corr, fig, _X_corr, _feature_names, _cmap, _norm, _right_cb, start_angle=-90.0)_x_map = "  ".join([f"X{i + 1}:{columns[i]}" for i in range(min(len(columns), len(_feature_names)))])fig.text(0.50.02, _x_map, ha="center", va="bottom", fontsize=12)plt.savefig("SHAP_与_Pearson_组合.png", dpi=800, bbox_inches="tight")plt.show()

总结

这张组合图通过横向双面板布局,将 SHAP 可视化与混合型相关性热力图有机结合:左侧以 “重要性条形图 + 蜂巢 / 小提琴图” 的双轴设计,同时量化特征重要性并展示其对模型输出的正负影响分布;右侧则用 “数值 + 动态扇形” 的混合型热力图,直观呈现因子间相关性的强度、方向与显著性,既深度解析了模型预测逻辑,又清晰揭示了驱动因子的内部关联,实现了信息密度与可读性的平衡,为机器学习模型解释提供了高效可视化方案。

!

点击蓝字 关注我们

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-02-28 08:58:51 HTTP/2.0 GET : https://f.mffb.com.cn/a/477132.html
  2. 运行时间 : 0.236739s [ 吞吐率:4.22req/s ] 内存消耗:4,756.58kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=a2041ff43fcebe72cf03d68a82199c0e
  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.000638s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.000657s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.002722s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.000255s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.000488s ]
  6. SELECT * FROM `set` [ RunTime:0.000293s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.000555s ]
  8. SELECT * FROM `article` WHERE `id` = 477132 LIMIT 1 [ RunTime:0.001214s ]
  9. UPDATE `article` SET `lasttime` = 1772240331 WHERE `id` = 477132 [ RunTime:0.012808s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 66 LIMIT 1 [ RunTime:0.021800s ]
  11. SELECT * FROM `article` WHERE `id` < 477132 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.003389s ]
  12. SELECT * FROM `article` WHERE `id` > 477132 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.004220s ]
  13. SELECT * FROM `article` WHERE `id` < 477132 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.023536s ]
  14. SELECT * FROM `article` WHERE `id` < 477132 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.020563s ]
  15. SELECT * FROM `article` WHERE `id` < 477132 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.009268s ]
0.240760s