当前位置:首页>python>马尔可夫链实战:用 Python 洞察市场牛熊震荡的秘密

马尔可夫链实战:用 Python 洞察市场牛熊震荡的秘密

  • 2026-06-30 03:09:24
马尔可夫链实战:用 Python 洞察市场牛熊震荡的秘密

用 Python 揭秘均值回归策略:你的收益从何而来?

2026年重磅升级已全面落地!欢迎加入专注财经数据与量化投研的【数据科学实战】知识星球!您将获取持续更新的《财经数据宝典》与《量化投研宝典》,双典协同提供系统化指引;星球内含 500 篇以上独有高质量文章,深度覆盖策略开发、因子分析、风险管理等核心领域,内容基本每日更新;同步推出的「量化因子专题教程」系列(含完整可运行代码与实战案例),系统详解因子构建、回测与优化全流程,并实现日更迭代。我们持续扩充独家内容资源,全方位赋能您的投研效率与专业成长。无论您是量化新手还是资深研究者,这里都是助您少走弯路、事半功倍的理想伙伴,携手共探数据驱动的投资未来!

引言

你是否好奇过:今天市场是牛市,明天还会继续牛下去吗?熊市结束后,更可能进入震荡还是直接反转?

这些问题,数学家 150 年前就给出了一个优雅的工具 —— 马尔可夫链(Markov Chain)。它不是什么稳赚不赔的圣杯,但它能让你用概率的视角,清晰地理解市场"状态切换"的规律。

本文将用 Python 带你一步步构建一个三状态(牛市 / 熊市 / 震荡)的市场机制切换模型,并诚实地告诉你:它能做什么,不能做什么


一、什么是随机过程?

随机过程(Stochastic Process) 就是一组按时间索引的随机变量:

  • • 离散时间:(例如每日收盘价)
  • • 连续时间:(例如逐笔成交价)

举三个例子,帮助你理解"时间索引"还不够,必须明确时间之间的依赖关系

  1. 1. 确定性过程,只有一条路径
  2. 2. 两条路径 或 ,各 1/2 概率,但路径在  就已确定
  3. 3. 每步独立:每个  独立取  或 ,路径剧烈震荡

这说明:依赖结构决定了过程的本质


二、马尔可夫性质:无记忆,但不神奇

如果一个离散时间随机过程满足下面这个性质,就叫做马尔可夫链

通俗翻译:下一步的概率只和当前状态有关,和更早的历史无关。

注意:这是一个假设,不是万能真理。金融收益率往往存在长期记忆和路径依赖。

一个反例:假如规则是"只有连续两次下跌之后才能上涨",那么下一步就依赖于前两步,这就不是一阶马尔可夫链了。不过可以通过扩展状态空间(比如定义状态 = (上一步动作, 当前位置))把它转化为一阶马尔可夫链。


三、用 Python 构建市场机制转移矩阵

3.1 定义三个市场状态

我们对 S&P 500 日收益率定义三个状态:

  • • State 0 —— 牛市(Bull):20 日累计收益率 > +2%
  • • State 1 —— 熊市(Bear):20 日累计收益率 < -2%
  • • State 2 —— 震荡(Sideways):介于两者之间

阈值 ±2% 是人为选择的,改变阈值会改变模型,一定要做鲁棒性测试

3.2 转移矩阵的极大似然估计

转移概率的自然估计就是:

完整的 Python 代码如下:

import numpy as np
import
 pandas as pd
import
 yfinance as yf

def
 label_states(returns, window=20, bull_thresh=0.02, bear_thresh=-0.02):
    # 计算 20 日滚动累计收益率

    rolling_ret = returns.rolling(window).sum()
    # 根据阈值打上状态标签:0 = 牛市,1 = 熊市,2 = 震荡

    states = np.where(rolling_ret > bull_thresh, 0,
             np.where(rolling_ret < bear_thresh, 1, 2))
    return
 pd.Series(states, index=returns.index)

def
 transition_matrix(states, n_states=3):
    # 初始化计数矩阵

    counts = np.zeros((n_states, n_states))
    vals = states.dropna().values.astype(int)
    # 统计每一对相邻状态的转移次数

    for
 i in range(len(vals) - 1):
        counts[vals[i], vals[i+1]] += 1
    # 按行归一化得到概率

    P = np.zeros_like(counts)
    for
 i in range(n_states):
        row_sum = counts[i].sum()
        if
 row_sum > 0:
            P[i] = counts[i] / row_sum
    return
 P

# 拉取 SPY 近 10 年日线数据

ticker = yf.Ticker("SPY")
df = ticker.history(period="10y", interval="1d")
returns = df['Close'].pct_change().dropna()

# 打标签 + 估计转移矩阵

states = label_states(returns)
P = transition_matrix(states)
print
(pd.DataFrame(P, index=['Bull', 'Bear', 'Side'],
                      columns=['Bull', 'Bear', 'Side']).round(3))

运行后,你可能得到类似这样的输出:

         Bull  Bear  Side
Bull     0.65  0.05  0.30
Bear     0.08  0.70  0.22
Side     0.20  0.10  0.70

解读:牛市有 65% 概率继续牛,熊市有 70% 概率继续熊 —— 市场状态确实具有持续性(persistence)


四、Chapman-Kolmogorov 方程与稳态分布

4.1 多步转移概率

从状态  经过  步到状态  的概率,就是矩阵  的  元素:

一行代码搞定:

def multi_step_prob(P, n_steps):
    # 用矩阵的 n 次幂直接计算 n 步转移概率

    return
 np.linalg.matrix_power(P, n_steps)

4.2 稳态分布

当  时,在不可约且非周期的条件下,状态分布会收敛到唯一的稳态分布

 就是长期来看市场停留在状态  的比例。

def stationary_distribution(P):
    n = P.shape[0]
    # 构造线性方程组:pi * P = pi,同时满足 sum(pi) = 1

    A = (P.T - np.eye(n))
    A[-1] = 1.0       # 用最后一行代替为"概率之和 = 1"的约束
    b = np.zeros(n)
    b[-1] = 1.0
    pi = np.linalg.solve(A, b)
    return
 pi

举例:如果 ,则长期看市场有 50% 时间震荡,30% 牛,20% 熊。

重要警告:稳态分布是一个渐进概念。真实市场是非平稳的,今天的转移矩阵未必明年还有效。


五、从状态概率到交易信号

5.1 基于期望收益的信号

设每个状态  的历史平均收益为 ,马尔可夫链给出下一期状态的概率 ,则期望收益为:

仓位应该与期望收益成正比,并按波动率缩放(比如凯利公式)。

5.2 鞅警告(Martingale Warning)

如果市场是鞅(效率市场假说的最简形式),那么:

没有任何马尔可夫链能产生正的期望利润。所以在实盘之前,务必检验:扣除交易成本后,条件期望收益是否显著不为零?


六、回测:走步前进(Walk-Forward)与那些你不能忽视的陷阱

走步前进法(在滚动历史窗口上重新估计转移矩阵)能避免前视偏差。但即使回测做对了,也要注意:

  • • 交易成本:每次双边 0.05%~0.10%,日频交易会吃掉大部分小幅优势
  • • 滑点:实际成交价往往比收盘价差
  • • 状态分类滞后:用 20 日滚动收益意味着你平均会晚 10 天才给一个状态打标签
  • • 非平稳性:2010—2015 年的转移矩阵在 2022—2023 年可能完全失效

务必对比以下基准:

  1. 1. 买入持有的 Sharpe
  2. 2. 200 日均线策略(往往比马尔可夫链还好)
  3. 3. 随机游走预测(零优势基准)

七、隐马尔可夫模型(HMM)简介

当状态不可直接观测时(这才更贴近真实金融市场),应该使用 HMM。真实状态  是隐藏的,你只观测到从状态相关分布中产生的收益率。

核心算法:

  • • Baum-Welch(EM):估计转移矩阵和发射参数
  • • Viterbi:找出最可能的隐状态序列

注意事项:

  1. 1. 局部最优:Baum-Welch 只收敛到似然的局部最大值,务必多次随机初始化
  2. 2. 分布误设:金融收益率有厚尾,假设高斯分布很危险,可以用 Student-t 或混合分布
  3. 3. 标签不可识别:哪个状态是"牛"是任意的,要根据平均收益重新排序
from hmmlearn import hmm
import
 numpy as np

def
 fit_hmm(returns, n_states=3, n_restarts=10):
    best_model = None
    best_score = -np.inf
    # 多次随机初始化,选择似然最高的模型

    for
 _ in range(n_restarts):
        model = hmm.GaussianHMM(n_components=n_states,
                                covariance_type="full",
                                n_iter=1000)
        model.fit(returns.values.reshape(-1, 1))
        score = model.score(returns.values.reshape(-1, 1))
        if
 score > best_score:
            best_score = score
            best_model = model
    return
 best_model

八、马尔可夫链能做和不能做什么

能做

  • • 建模市场状态的持续性(牛 / 熊 / 震荡)
  • • 计算长期稳态概率(熊市长期占多少比例)
  • • 给出状态概率的多步预测
  • • 作为更复杂模型(比如 GARCH 波动率切换)的基础构件

不能做

  • • "稳定盈利"—— 没有任何数学模型能在无套利条件下保证这点
  • • 在缺乏额外信息源(风险溢价、微观结构、资金流)的情况下战胜效率市场
  • • 在不考虑交易成本、状态定义鲁棒性和非平稳性的情况下可靠工作
  • • 用样本内交叉验证替代真正的样本外回测

九、完整回测框架(含交易成本)

import numpy as np
import
 pandas as pd
import
 yfinance as yf

class
 RegimeMarkovModel:
    def
 __init__(self, lookback=252, regime_window=20,
                 bull_thresh=0.02, bear_thresh=-0.02,
                 transaction_cost=0.001
):
        # 历史窗口、阈值、交易成本的设置

        self
.lookback = lookback
        self
.regime_window = regime_window
        self
.bull_thresh = bull_thresh
        self
.bear_thresh = bear_thresh
        self
.transaction_cost = transaction_cost

    def
 label_states(self, returns):
        # 打标签:牛 / 熊 / 震荡

        rolling_ret = returns.rolling(self.regime_window).sum()
        states = np.where(rolling_ret > self.bull_thresh, 0,
                 np.where(rolling_ret < self.bear_thresh, 1, 2))
        return
 pd.Series(states, index=returns.index)

    def
 estimate_transition(self, states):
        # 估计转移矩阵

        n = 3
        counts = np.zeros((n, n))
        vals = states.dropna().values.astype(int)
        for
 i in range(len(vals) - 1):
            counts[vals[i], vals[i+1]] += 1
        P = np.zeros_like(counts)
        for
 i in range(n):
            s = counts[i].sum()
            if
 s > 0:
                P[i] = counts[i] / s
        return
 P

    def
 regime_returns(self, states, returns):
        # 计算各状态的历史平均收益

        df = pd.DataFrame({'ret': returns, 'state': states}).dropna()
        return
 df.groupby('state')['ret'].mean().values

    def
 run_backtest(self, returns):
        states = self.label_states(returns)
        signals, positions, dates = [], [], []

        # 走步前进:每天用过去 lookback 天的数据重新估计

        for
 i in range(self.lookback, len(states)):
            hist_states = states.iloc[i - self.lookback:i]
            hist_returns = returns.iloc[i - self.lookback:i]
            P = self.estimate_transition(hist_states)
            mu = self.regime_returns(hist_states, hist_returns)

            # 根据当前状态计算下一期期望收益

            current_state = int(states.iloc[i])
            next_probs = P[current_state]
            expected_return = np.dot(next_probs, mu)

            # 基于期望收益打开多头 / 空头 / 空仓

            if
 expected_return > 0.0005:      # 5 bps 的噪音阈值
                pos = 1.0
            elif
 expected_return < -0.0005:
                pos = -1.0
            else
:
                pos = 0.0

            positions.append(pos)
            signals.append(expected_return)
            dates.append(states.index[i])

        positions = pd.Series(positions, index=dates)
        strategy_ret = positions.shift(1) * returns.loc[dates]

        # 扣除仓位变动带来的交易成本

        pos_changes = positions.diff().fillna(0).abs()
        costs = pos_changes * self.transaction_cost
        net_ret = strategy_ret - costs

        # 计算绩效指标

        sharpe = net_ret.mean() / net_ret.std() * np.sqrt(252)
        cum = (1 + net_ret).cumprod()
        max_dd = (cum / cum.cummax() - 1).min()

        return
 net_ret, sharpe, max_dd

# 运行回测

data = yf.Ticker("SPY").history(period="15y", interval="1d")
rets = data['Close'].pct_change().dropna()
model = RegimeMarkovModel(transaction_cost=0.001)
net_ret, sharpe, mdd = model.run_backtest(rets)
print
(f"扣除成本后的 Sharpe: {sharpe:.3f}, 最大回撤: {mdd:.2%}")

你多半会看到:扣除成本后 Sharpe 大约在 0.2 ~ 0.5 之间,通常还不如简单的买入持有。这就是现实


总结

马尔可夫链是非常优美的数学工具,对于状态识别风险管理确实有用。但它不是稳定盈利的秘密武器

在你部署任何此类策略之前,请扪心自问:

  1. 1. 期望收益信号是否能盖过交易成本和滑点?
  2. 2. 模型是否在多个样本外周期(比如 2008、2020、2022)测试过?
  3. 3. 所谓的"优势"对不同的状态定义和阈值是否鲁棒?

最终一句话:用马尔可夫链去理解概率,而不是去追逐盈利。真正的优势,就藏在这份理解之中。


参考文章

加入专注于财经数据与量化投研的知识星球【数据科学实战】,获取本文完整研究解析、代码实现细节。

财经数据与量化投研知识社区

2026年全面升级已落地!【数据科学实战】知识星球核心权益如下:

  1. 1. 双典系统赋能:获赠《财经数据宝典》与《量化投研宝典》完整文档,凝练多年实战经验,构建系统化知识框架;
  2. 2. 量化因子日更教程(2026重磅新增):每日更新「量化因子专题教程」,配套完整可运行代码与实战案例,深度拆解因子构建、回测与优化全流程;
  3. 3. 量化文章专题教程库:500+篇星球独有高质量教程式文章,系统覆盖策略开发、因子研究、风险管理等核心领域,内容基本每日更新,并配套精选学习资料与实战参考;
  4. 4. 量化投研实战课程:赠送《AKQuant-入门及实战》《PyBroker-入门及实战》视频课程,手把手教学,快速掌握量化策略开发技能;
  5. 5. 财经数据支持:定期更新国内外财经数据,为策略研发提供精准、可靠的数据基础;
  6. 6. 顶尖学者与行业专家分享:年度邀请学术界博士与业界资深专家开展前沿论文精讲与实战案例分享,不少于4场,直击研究前沿与产业实践;
    专家直连答疑:与核心开发者及领域专家实时互动,高效解决投研实战难题;
  7. 7. 专业社群与专属福利:加入高质量交流社群,获取课程折扣及更多独家资源。

星球已沉淀丰富内容生态——涵盖量化文章专题教程库、因子日更系列、高频数据集、PyBroker实战课程、专家深度分享与实时答疑服务。无论您是初探量化的学习者,还是深耕领域的从业者,这里都是助您少走弯路、高效成长的理想平台。诚邀加入,共探数据驱动的投资未来!

好文推荐

1. 用 Python 打造股票预测系统:Transformer 模型教程(一)

2. 用 Python 打造股票预测系统:Transformer 模型教程(二)

3. 用 Python 打造股票预测系统:Transformer 模型教程(三)

4. 用 Python 打造股票预测系统:Transformer 模型教程(完结)

5. 揭秘隐马尔可夫模型:因子投资的制胜武器

6. YOLO 也能预测股市涨跌?计算机视觉在股票市场预测中的应用

7. 金融 AI 助手:FinGPT 让你轻松掌握市场分析

8. 量化交易秘籍:为什么专业交易员都在用对数收益率?

9. Python 量化投资利器:Ridge、Lasso 和 Elastic Net 回归详解

10. 掌握金融波动率模型:完整 Python 实现指南

好书推荐

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-07-03 08:28:45 HTTP/2.0 GET : https://f.mffb.com.cn/a/493542.html
  2. 运行时间 : 0.093613s [ 吞吐率:10.68req/s ] 内存消耗:4,741.59kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=d48b0f55a6818beee0def9246ba7f335
  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.000773s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.000915s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.000338s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.000275s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.000470s ]
  6. SELECT * FROM `set` [ RunTime:0.000195s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.000488s ]
  8. SELECT * FROM `article` WHERE `id` = 493542 LIMIT 1 [ RunTime:0.007828s ]
  9. UPDATE `article` SET `lasttime` = 1783038525 WHERE `id` = 493542 [ RunTime:0.004632s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 66 LIMIT 1 [ RunTime:0.000240s ]
  11. SELECT * FROM `article` WHERE `id` < 493542 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.000370s ]
  12. SELECT * FROM `article` WHERE `id` > 493542 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.000371s ]
  13. SELECT * FROM `article` WHERE `id` < 493542 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.000985s ]
  14. SELECT * FROM `article` WHERE `id` < 493542 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.008141s ]
  15. SELECT * FROM `article` WHERE `id` < 493542 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.001265s ]
0.095187s