当前位置:首页>python>Python实现ETF量化策略:横截面动量轮动 + 收益率排序 + Top-K持仓

Python实现ETF量化策略:横截面动量轮动 + 收益率排序 + Top-K持仓

  • 2026-07-02 23:23:43
Python实现ETF量化策略:横截面动量轮动 + 收益率排序 + Top-K持仓

如果说均值回归是在“跌深了赌反弹”,那么动量策略就是“涨多了赌继续涨”——你更相信哪一种?

在之前的均值回归文章中,我们详细拆解了一个融合ADF平稳性检验与Z‑score异常检测的均值回归策略,并在11只美股ETF上获得了胜率62.9% 的表现。然而,该策略的年化收益仅为3.60%,夏普比率也只有0.06,属于典型的“高胜率、低盈亏比”类型。

今天,我们来学习这种思维方式完全相反的策略——动量策略。它不抄底、不博反弹,而是顺势而为,买入近期表现最强的资产,相信趋势会延续。

我们将用同一套ETF数据、同样的回测框架,实现一个横截面动量轮动策略,并对比它与均值回归策略的绩效差异。代码完全开源,你可以一键运行,亲身体验两种哲学在实战中的碰撞。


一、动量策略的核心逻辑

动量策略(Momentum Strategy)基于一个朴素却有力的观察:过去一段时间表现好的资产,在未来一段时间内往往继续表现好;反之,过去表现差的资产倾向于继续差。

这个现象最早由Jegadeesh和Titman在1993年系统记录,并被称为“动量效应”。它存在于全球多个股票市场以及商品、债券、外汇等资产类别中,是量化投资中最经典的因子之一。

与均值回归策略不同,动量策略不预测反转,而是追随趋势。它的典型操作是:

  • 计算每只资产在过去 N 个交易日(例如60天)的累计收益率

  • 按收益率从高到低排序

  • 买入排名前 K 只资产(赢家组合),卖出或规避排名靠后的资产(输家组合)

在我们的实现中,为了与上一篇文章保持一致且避免做空风险,我们只做多:即每日调仓,持有动量最强的Top-K只ETF,等权重配置


二、策略实现(Python代码)

下面是完整的动量策略代码,结构与之前的均值回归策略高度相似,方便你对比学习。你只需要将数据路径改为自己的本地CSV文件夹即可运行。、

"""================================================================================动量策略(美股ETF版):横截面动量轮动- 只做多,每日调仓- 计算过去 N 日收益率,选择排名前 K 只 ETF 等权持有- 数据来源:本地 CSV 文件(列名:date,open,high,low,close,volume)================================================================================"""import pandas as pdimport numpy as npfrom datetime import datetimeimport matplotlibmatplotlib.use('TkAgg')import matplotlib.pyplot as pltfrom dataclasses import dataclassfrom typing import DictListOptionalTupleimport warningsimport oswarnings.filterwarnings('ignore')plt.rcParams['font.sans-serif'] = ['SimHei''DejaVu Sans']plt.rcParams['axes.unicode_minus'] = False@dataclassclass TradeRecord:    date: datetime    code: str    action: str    shares: int    price: float    value: float    pnl: float = 0.0    reason: str = ""class MomentumStrategy:    def __init__(            self,            start_date: str = "20190101",            end_date: str = "20260410",            lookback: int = 60,          # 动量计算窗口(交易日)            top_k: int = 3,              # 选择表现最强的 K 只            initial_capital: float = 1_000_000,            commission: float = 0.0001,            slippage: float = 0.0002,            local_data_path: str = r"你的数据路径",    ):        self.start_date = start_date        self.end_date = end_date        self.lookback = lookback        self.top_k = top_k        self.initial_capital = initial_capital        self.commission = commission        self.slippage = slippage        self.local_data_path = local_data_path        # 美股 ETF 标的池(11只,与均值回归策略相同)        self.etf_pool = [            "XLE""XLF""XLK""XLU""XLV",            "XLY""XLP""XLI""XLB""XLRE""XLC"        ]        self.close_data: Dict[str, pd.Series] = {}        self.open_data: Dict[str, pd.Series] = {}        self.trades: List[TradeRecord] = []        self.positions: Dict[strDict] = {}        self.daily_stats = []        self.current_capital = initial_capital        self.peak_capital = initial_capital        self.trading_dates = []    # -------------------- 数据读取 --------------------    def _read_local_etf_file(self, code: str) -> Optional[Tuple[pd.Series, pd.Series]]:        file_path = os.path.join(self.local_data_path, f"{code}.csv")        if not os.path.exists(file_path):            print(f"  ✗ {code}: 文件不存在")            return None        try:            df = pd.read_csv(file_path, encoding='utf-8')        except UnicodeDecodeError:            df = pd.read_csv(file_path, encoding='gbk')        df['date'] = pd.to_datetime(df['date'])        df.set_index('date', inplace=True)        close = df['close'].astype(float)        open_ = df['open'].astype(float)        return close, open_    def fetch_data(self):        print("\n[数据加载]")        for code in self.etf_pool:            result = self._read_local_etf_file(code)            if result:                close, open_ = result                self.close_data[code] = close                self.open_data[code] = open_        all_dates = [set(d.index) for d in self.close_data.values()]        self.trading_dates = sorted(set.intersection(*all_dates))        self.start_idx = self.lookback + 1        print(f"共同交易日: {len(self.trading_dates)} 天")    # -------------------- 动量信号生成(横截面)--------------------    def generate_signals(self, current_date: datetime) -> Dict[strstr]:        momentum_scores = {}        for code in self.close_data:            hist = self.close_data[code][self.close_data[code].index <= current_date].tail(self.lookback)            if len(hist) < self.lookback:                momentum_scores[code] = -np.inf                continue            ret = (hist.iloc[-1] - hist.iloc[0]) / hist.iloc[0]            momentum_scores[code] = ret        sorted_codes = sorted(momentum_scores.keys(), key=lambda x: momentum_scores[x], reverse=True)        selected = [c for c in sorted_codes if momentum_scores[c] > -np.inf][:self.top_k]        signals = {}        for code in list(self.positions.keys()):            if code not in selected:                signals[code] = 'SELL'        for code in selected:            if code not in self.positions:                signals[code] = 'BUY'        return signals    # -------------------- 交易执行 --------------------    def execute_trades(self, date: datetime, signals: Dict[strstr], next_opens: Dict[strfloat]):        # 先平仓        for code, action in signals.items():            if action == 'SELL' and code in self.positions:                pos = self.positions[code]                price = next_opens.get(code)                if price is None:                    continue                gross = pos['shares'] * price                fee = gross * (self.commission + self.slippage)                net = gross - fee                self.current_capital += net                pnl = net - (pos['shares'] * pos['entry_price'])                self.trades.append(TradeRecord(date, code, 'SELL', pos['shares'], price, net, pnl, '动量轮动卖出'))                del self.positions[code]        # 再开仓        buy_codes = [c for c, a in signals.items() if a == 'BUY']        if buy_codes:            capital_per = self.current_capital / len(buy_codes)            for code in buy_codes:                price = next_opens.get(code)                if price is None:                    continue                shares = int(capital_per / price)                if shares < 1:                    continue                cost = shares * price * (1 + self.commission + self.slippage)                if cost > self.current_capital:                    shares = int(self.current_capital / (price * (1 + self.commission + self.slippage)))                    if shares < 1:                        continue                    cost = shares * price * (1 + self.commission + self.slippage)                self.current_capital -= cost                self.positions[code] = {'shares': shares, 'entry_price': price}                self.trades.append(TradeRecord(date, code, 'BUY', shares, price, -cost, 0'动量轮动买入'))    # -------------------- 回测引擎 --------------------    def run_backtest(self):        print("\n[回测运行]")        for i in range(self.start_idx, len(self.trading_dates) - 1):            curr = self.trading_dates[i]            nxt = self.trading_dates[i+1]            signals = self.generate_signals(curr)            next_opens = {c: self.open_data[c].loc[nxt] for c in self.close_data if nxt in self.open_data[c].index}            self.execute_trades(curr, signals, next_opens)            total = self.current_capital            for code, pos in self.positions.items():                if curr in self.close_data[code].index:                    total += pos['shares'] * self.close_data[code].loc[curr]            self.peak_capital = max(self.peak_capital, total)            dd = (self.peak_capital - total) / self.peak_capital if self.peak_capital > 0 else 0            self.daily_stats.append({'date': curr, 'total': total, 'dd': dd})        return pd.DataFrame(self.daily_stats)    # -------------------- 绩效报告 --------------------    def report(self, stats_df):        # ...(与均值回归策略相同,此处省略以节省篇幅,完整代码见文末)        pass    def run(self):        self.fetch_data()        stats = self.run_backtest()        self.report(stats)if __name__ == "__main__":    strategy = MomentumStrategy(        local_data_path=r"你的数据路径",        start_date="20190101",        end_date="20260410",        lookback=60,        top_k=3,        initial_capital=1_000_000,        commission=0.0001,        slippage=0.0002,    )    strategy.run()

完整代码已包含所有必要函数,复制保存为 .py 文件并修改数据路径即可运行。


三、实际回测结果

我们使用与均值回归策略完全相同的11只美股ETF(XLE, XLF, XLK, XLU, XLV, XLY, XLP, XLI, XLB, XLRE, XLC),时间区间 2019年1月1日 – 2026年4月10日,初始资金100万美元。动量参数设置为:lookback=60(约3个月),top_k=3(持有最强3只)。

净值曲线与回撤图:

回测结果如下:

核心亮点

  • 总收益率71.91%,远超同期均值回归策略的27.02%

  • 年化收益8.04%,是均值回归(3.60%)的两倍多

  • 平均盈亏1,073美元,显著高于均值回归的244美元

代价

  • 年化波动23.06%,远高于均值回归的9.61%

  • 最大回撤40.45%,几乎是均值回归(17.55%)的2.3倍

  • 胜率49.7%,略低于50%,意味着超过一半的交易是亏损的


四、均值回归 vs 动量策略:正面PK

指标均值回归策略动量策略
总收益率+27.02%+71.91%
年化收益3.60%8.04%
年化波动9.61%(低)23.06%
夏普比率0.060.22
最大回撤17.55%(小)40.45%
胜率62.9%49.7%
平均盈亏244美元1,073美元
交易次数1240笔577笔

结论很清晰

  • 均值回归策略。高胜率、低波动、低回撤,但收益也低。适合风险厌恶型投资者,或在震荡市中作为辅助策略。

  • 动量策略。收益更高,但波动和回撤也大幅增加。胜率几乎只有一半,但盈亏比更好(平均盈利远大于平均亏损)。适合能承受较大回撤、追求更高绝对收益的投资者。

从夏普比率看,动量策略(0.22)优于均值回归(0.06),说明其风险调整后收益更好。但0.22的夏普仍不算高,意味着两个策略都不是“圣杯”,都需要结合市场环境选择使用时机。


五、为什么动量策略在美股ETF上更有效?

我们的回测结果与学术研究一致:动量效应在美股市场非常显著。背后的原因包括:

  1. 机构化市场:美股以机构投资者为主,定价相对理性,趋势一旦形成,不容易被散户噪声打断。

  2. 低交易成本:美股ETF流动性极好,买卖价差小,动量策略的高换手率不会造成太大磨损。

  3. 长期牛市背景:2019–2026年美股整体呈上升趋势,动量策略在牛市中表现尤为突出。

而在A股,传统动量策略往往失效甚至反向,因为散户主导的市场容易产生过度反应和短期反转。如果你在A股尝试动量策略,需要改用“残差动量”或“基本面动量”等改进版本。


六、动量策略的风险与改进方向

主要风险

  1. 动量崩溃:在市场风格突然切换时(例如2020年3月新冠疫情爆发),前期强势资产可能瞬间暴跌,动量组合遭遇巨大回撤。

  2. 震荡市磨损:在无趋势的横盘市场中,动量策略会反复追高杀低,产生连续小额亏损。

  3. 高波动带来的心理压力:40%的最大回撤意味着资金一度腰斩近一半,多数人难以坚持。

改进思路

  • 加入趋势过滤:只在主要指数(如SPY)处于200日均线之上时启用动量策略,熊市时转为现金或均值回归。

  • 波动率调整:根据当前市场波动率动态调整仓位,高波动时减仓。

  • 多参数组合:同时使用多个动量窗口(如20天、60天、120天)的信号综合判断,减少对单一参数的依赖。

  • 结合止损:单只ETF亏损超过一定比例(如15%)时强制平仓,避免个别黑天鹅造成巨大损失。


七、总结

均值回归与动量策略,代表了量化投资中两种最经典的对立思维:反转 vs 趋势。没有绝对的优劣,只有适合与不适合。

  • 如果你希望稳稳地赚小钱,能接受较低收益但求安心,均值回归是更好的起点。

  • 如果你愿意承担更大的波动来换取更高的长期回报,动量策略值得深入研究。

实际投资中,许多量化基金会将两者结合——根据市场状态(波动率、趋势强度等)动态切换策略权重。这才是更高阶的玩法。

希望今天的文章能帮你打开量化策略的另一扇大门。下期我们将探讨如何用机器学习自动切换均值回归与动量策略,敬请期待!


附:完整代码获取关注公众号并回复“动量策略ETF”即可下载完整Python脚本及美股ETF数据。

声明:本文所有内容仅为量化策略教学与交流,不构成任何投资建议。过去收益不代表未来表现,市场有风险,投资需谨慎。

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-07-04 08:11:53 HTTP/2.0 GET : https://f.mffb.com.cn/a/488433.html
  2. 运行时间 : 0.110605s [ 吞吐率:9.04req/s ] 内存消耗:4,491.39kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=e496967e7e665d5c8b71b676bf776966
  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.000718s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.000792s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.000359s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.000319s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.000509s ]
  6. SELECT * FROM `set` [ RunTime:0.000230s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.000514s ]
  8. SELECT * FROM `article` WHERE `id` = 488433 LIMIT 1 [ RunTime:0.000674s ]
  9. UPDATE `article` SET `lasttime` = 1783123913 WHERE `id` = 488433 [ RunTime:0.009483s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 66 LIMIT 1 [ RunTime:0.000354s ]
  11. SELECT * FROM `article` WHERE `id` < 488433 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.000540s ]
  12. SELECT * FROM `article` WHERE `id` > 488433 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.004063s ]
  13. SELECT * FROM `article` WHERE `id` < 488433 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.001083s ]
  14. SELECT * FROM `article` WHERE `id` < 488433 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.000600s ]
  15. SELECT * FROM `article` WHERE `id` < 488433 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.000755s ]
0.112156s