当前位置:首页>python>Python实战:使用PuLP库解决线性规划问题

Python实战:使用PuLP库解决线性规划问题

  • 2026-06-30 17:17:25
Python实战:使用PuLP库解决线性规划问题

本文作者:赵语涵 中南财经政法大学统计与数学学院

本文编辑:梁莹

技术总编:兰博文

Stata and Python 数据分析

爬虫俱乐部Stata数据处理与实证研究实战、Python基础编程与文本分析进阶课程可在小鹅通平台查看,欢迎大家多多支持订阅!如需了解详情,可以通过课程链接(https://appbqiqpzi66527.h5.xiaoeknow.com/homepage/10)或课程二维码进行访问哦~

 引    言 
在实际运营决策中,企业往往需要在多重约束下做出系统性选择,例如:在哪里建厂、是否进行产能投资、以及如何安排生产与配送。这类问题往往彼此关联,单独优化某一环节,容易导致整体效率或利润下降。

线性规划为此提供了一种统一的建模语言。通过明确目标函数与约束条件,可以在给定条件下求得全局最优解。本文以一个“三阶段决策问题”为例,依次构建选址、投资与生产模型,展示如何使用 Python 中的 PuLP 库,将复杂运营决策转化为可求解的线性规划问题。

 实 操 步 骤 
01
数据展示
具体数据表包含:
候选工厂基础信息表(建厂成本与基础产能):描述每个候选工厂的固定建设成本、未投资情况下的基础产能,以及由于区位差异带来的单位生产成本附加,是选址与投资阶段的核心基础表。
市场基本信息表(市场权重):描述不同市场的重要性权重,用于在选址阶段放大关键市场的运输影响,在生产阶段体现市场优先级。
产品信息表(价格与基础生产成本):给出各产品的单位销售价格与基础生产成本,是第三阶段利润计算的核心输入。
市场–产品需求表:描述不同市场对不同产品的需求规模,是生产与配送阶段的“需求端约束”。
工厂到市场运输成本表:给出各工厂向各市场发货的单位运输成本,既参与选址阶段的长期区位权衡,也参与生产阶段的边际成本计算。
产品资源消耗表(单位劳动与材料用量):描述每生产一单位产品所需的劳动和材料,是生产阶段全局资源约束的依据。
全局资源供给上限表:给出企业在规划周期内可用的总劳动量和材料量,与 bom 表共同决定生产的可行上限。
工厂产能升级方案表:描述各工厂可选的产能投资方案,包括升级成本和产能增量,是投资阶段的决策核心。
模型全局参数配置表:集中管理选址数量、投资预算、服务水平要求、是否允许缺货以及缺货惩罚等全局性参数,用于统一控制三阶段模型行为。
02
数据解读与导入

本案例刻画的是一个典型的中长期运营决策流程:先进行工厂选址,再决定是否进行产能投资,最后在既定产能条件下安排生产与配送。这种决策具有明确的先后依赖关系,因此在数据层面需要进行分阶段组织。

为此,数据被拆分为选址、投资与生产三类核心信息。选址相关数据描述候选工厂的固定建设成本、基础产能以及区位差异;投资数据刻画不同工厂可选的产能升级方案及其成本;生产与配送数据则给出产品价格、需求规模、运输成本以及全局资源约束。此外,部分关键参数(如选址数量、投资预算、服务水平要求)被集中存放,便于统一调整。

在建模前,首先从 Excel 文件中读取各类数据,并整理为 Python 中便于索引的字典与列表结构,为后续线性规划建模做准备。

import pandas as pdimport pulp as plFILE = "lp_realistic_data_v2.xlsx"sites_df   = pd.read_excel(FILE, sheet_name="sites")mkts_df    = pd.read_excel(FILE, sheet_name="markets")prod_df    = pd.read_excel(FILE, sheet_name="products")demand_df  = pd.read_excel(FILE, sheet_name="demand")ship_df    = pd.read_excel(FILE, sheet_name="shipping")bom_df     = pd.read_excel(FILE, sheet_name="bom")rlim_df    = pd.read_excel(FILE, sheet_name="resource_limits")upg_df     = pd.read_excel(FILE, sheet_name="site_upgrades")params_df  = pd.read_excel(FILE, sheet_name="params")sites    = sites_df["site"].tolist()markets  = mkts_df["market"].tolist()products = prod_df["product"].tolist()fixed_cost = dict(zip(sites_df["site"], sites_df["fixed_cost"]))base_cap   = dict(zip(sites_df["site"], sites_df["base_capacity"]))site_addon = dict(zip(sites_df["site"], sites_df["prod_cost_addon"]))mkt_weight = dict(zip(mkts_df["market"], mkts_df["weight"]))price          = dict(zip(prod_df["product"], prod_df["unit_price"]))base_unit_cost = dict(zip(prod_df["product"], prod_df["base_unit_cost"]))demand    = {(r["market"], r["product"]): float(r["demand"]) for _, r in demand_df.iterrows()}ship_cost = {(r["site"], r["market"]): float(r["ship_cost"]) for _, r in ship_df.iterrows()}labor_use = dict(zip(bom_df["product"], bom_df["labor_per_unit"]))mat_use   = dict(zip(bom_df["product"], bom_df["material_per_unit"]))res_limit = dict(zip(rlim_df["resource"], rlim_df["limit"]))params = dict(zip(params_df["param"], params_df["value"]))K              = int(params["K"])INVEST_BUDGET  = float(params["INVEST_BUDGET"])SERVICE_LEVEL  = float(params["SERVICE_LEVEL"])ALLOW_BACKORDER = int(params["ALLOW_BACKORDER"])SHORT_PENALTY  = float(params.get("SHORT_PENALTY", 0.0))TOTAL_DEMAND = sum(demand[(m, p)] for m in markets for p in products)mkt_total_demand = {m: sum(demand[(m, p)] for p in products) for m in markets}
03
选址问题

选址阶段回答的是一个结构性问题:在多个候选工厂中,应当选择哪些地点进行建设。该决策一旦做出,将长期影响后续的投资与生产安排,因此需要从整体成本角度进行优化。

在模型中,每个候选工厂对应一个 0–1 决策变量,表示是否选址。目标函数由两部分构成:固定建设成本,以及基于市场需求加权后的运输成本,用以刻画不同区位带来的长期差异。约束条件则要求最终选出的工厂数量恰好等于预设的 K。

代码的核心逻辑是:在满足“选址数量约束”的前提下,寻找使综合成本最小的一组工厂组合。

m1 = pl.LpProblem("Location", pl.LpMinimize)open_site = pl.LpVariable.dicts("open", sites, 01, cat=pl.LpBinary)m1 += (    pl.lpSum(fixed_cost[s] * open_site[s] for s in sites)    + pl.lpSum(        mkt_weight[m] * mkt_total_demand[m] * ship_cost[(s, m)] * open_site[s]        for s in sites for m in markets    ))m1 += pl.lpSum(open_site[s] for s in sites) == Km1.solve(pl.PULP_CBC_CMD(msg=False))selected_sites = [s for s in sites if pl.value(open_site[s]) > 0.5]print("Status:", pl.LpStatus[m1.status])print("Selected sites:", selected_sites)print("Objective (location):", pl.value(m1.objective))print()if pl.LpStatus[m1.status] != "Optimal":    raise RuntimeError("Part 1 did not solve to optimal. Check data/constraints.")
模型求解结果如图显示,在当前数据下选择 S1 与 S3 能够使选址阶段的综合成本最小。该结果直接作为下一阶段投资决策的可行集合。
04
投资问题

在确定选址之后,投资阶段的目标转为:在预算约束下,决定是否对已选工厂进行产能升级,以最大化可用产能。

模型中为每一个“工厂–升级方案”组合设置 0–1 决策变量。目标函数最大化产能增量总和,同时通过约束保证:升级只能发生在已选址工厂、每个工厂最多选择一个升级方案、且总投资不超过预算。

代码本质上是在做一件事:在给定预算内,为已选工厂挑选“性价比最高”的升级组合。

m2 = pl.LpProblem("Investment", pl.LpMaximize)upg_pairs = [(r["site"], r["upgrade"]) for _, r in upg_df.iterrows()]upg_cost  = {(r["site"], r["upgrade"]): float(r["upgrade_cost"]) for _, r in upg_df.iterrows()}upg_gain  = {(r["site"], r["upgrade"]): float(r["capacity_gain"]) for _, r in upg_df.iterrows()}x = pl.LpVariable.dicts("upgrade", upg_pairs, 0, 1, cat=pl.LpBinary)m2 += pl.lpSum(upg_gain[pair] * x[pair] for pair in upg_pairs)for (s, u) in upg_pairs:    m2 += x[(s, u)] <= (1 if s in selected_sites else 0)for s in selected_sites:    m2 += pl.lpSum(x[(ss, u)] for (ss, u) in upg_pairs if ss == s) <= 1m2 += pl.lpSum(upg_cost[pair] * x[pair] for pair in upg_pairs) <= INVEST_BUDGETm2.solve(pl.PULP_CBC_CMD(msg=False))chosen_upgrades = [pair for pair in upg_pairs if pl.value(x[pair]) > 0.5]final_cap = {}for s in sites:    cap = base_cap[s] * (1 if s in selected_sites else 0)    for (ss, u) in chosen_upgrades:        if ss == s:            cap += upg_gain[(ss, u)]    final_cap[s] = capTOTAL_CAP = sum(final_cap[s] for s in selected_sites)INV_USED = sum(upg_cost[pair] for pair in chosen_upgrades)print("Status:", pl.LpStatus[m2.status])print("Chosen upgrades:", chosen_upgrades if chosen_upgrades else "None")print(f"Invest used: {INV_USED} / {INVEST_BUDGET}")print("Final capacity (selected sites):", {s: final_cap[s] for s in selected_sites})print("Total final capacity:", TOTAL_CAP)print()if pl.LpStatus[m2.status] != "Optimal":    raise RuntimeError("Part 2 did not solve to optimal. Check data/constraints.")

结果表明,在预算允许范围内,对 S1 与 S3 同时实施 U1 升级可以获得最大的产能提升,形成后续生产阶段的产能上限。

05
生产问题

在选址与投资结果确定后,生产阶段关注的是运营层面的配置问题:如何在既定产能和资源约束下,安排生产与配送以实现利润最大化。

模型的连续型决策变量表示各工厂向各市场供应不同产品的数量,并允许在需求无法完全满足时产生缺货。目标函数综合考虑销售收入、生产成本、运输成本以及缺货惩罚;约束条件则包括需求平衡、产能限制、劳动力与材料上限,以及整体服务水平要求。

代码的整体逻辑是:在满足服务水平底线的前提下,将有限产能优先分配给“边际贡献更高”的市场与产品组合。

m3 = pl.LpProblem("Production_and_Shipping", pl.LpMaximize)ship = pl.LpVariable.dicts(    "ship",    [(s, m, p) for s in selected_sites for m in markets for p in products],    lowBound=0,    cat=pl.LpContinuous)short = pl.LpVariable.dicts(    "short",    [(m, p) for m in markets for p in products],    lowBound=0,    cat=pl.LpContinuous)m3 += pl.lpSum(    price[p] * ship[(s, m, p)]    - (base_unit_cost[p] + site_addon[s]) * ship[(s, m, p)]    - ship_cost[(s, m)] * ship[(s, m, p)]    for s in selected_sites for m in markets for p in products) - SHORT_PENALTY * pl.lpSum(short[(m, p)] for m in markets for p in products)for m in markets:    for p in products:        m3 += pl.lpSum(ship[(s, m, p)] for s in selected_sites) + short[(m, p)] == demand[(m, p)]if ALLOW_BACKORDER == 0:    for m in markets:        for p in products:            m3 += short[(m, p)] == 0for s in selected_sites:    m3 += pl.lpSum(ship[(s, m, p)] for m in markets for p in products) <= final_cap[s]m3 += pl.lpSum(labor_use[p] * ship[(s, m, p)] for s in selected_sites for m in markets for p in products) <= res_limit["labor"]m3 += pl.lpSum(mat_use[p]   * ship[(s, m, p)] for s in selected_sites for m in markets for p in products) <= res_limit["material"]m3 += pl.lpSum(ship[(s, m, p)] for s in selected_sites for m in markets for p in products) >= SERVICE_LEVEL * TOTAL_DEMANDm3.solve(pl.PULP_CBC_CMD(msg=False))
求解结果如图所示,在资源受限条件下,模型仍实现了接近 98% 的整体履约率,且仅在边际收益较低的市场–产品组合上产生少量缺货。两处工厂均满负荷运行,说明产能约束是当前系统的主要瓶颈。运营利润与扣除固定成本后的净利润,为评估整套三阶段决策的经济性提供了直接依据。
 结    论 

通过将选址、投资与生产三个决策阶段拆分建模,可以清晰地看到不同层级决策之间的约束传导关系。线性规划在此过程中并不依赖历史样本拟合,而是直接刻画“在给定规则下,什么配置是最优的”。

PuLP 提供了一种将数学模型与代码结构高度对齐的实现方式,使复杂运营问题可以被透明地建模、求解与复核。对于存在明确约束、且决策变量之间关系可线性刻画的场景,这类方法能够为实际决策提供稳定、可解释的定量支持。

声明:代码仅供学习使用,请勿用做任何商业行为!

重磅福利!为了更好地服务各位同学的研究,爬虫俱乐部将在小鹅通平台上持续提供金融研究所需要的各类指标,包括上市公司十大股东、股价崩盘、投资效率、融资约束、企业避税、分析师跟踪、净资产收益率、资产回报率、国际四大审计、托宾Q值、第一大股东持股比例、账面市值比、沪深A股上市公司研究常用控制变量等一系列深加工数据,基于各交易所信息披露的数据利用Stata在实现数据实时更新的同时还将不断上线更多的数据指标。我们以最前沿的数据处理技术、最好的服务质量、最大的诚意望能助力大家的研究工作!相关数据链接,请大家访问:(https://appbqiqpzi66527.h5.xiaoeknow.com/homepage/10)或扫描二维码:

对我们的推文累计打赏超过1000元,我们即可给您开具发票,发票类别为“咨询费”。用心做事,不负您的支持!

期推文推荐
Stata入门:statsby命令详解—分组统计的“效率神器”
Python实战:DrissionPage 一键查询商品历史价格

Stata中codebook命令介绍及应用

Stata绘制热力图
自动化报告生成:sum2docx与reg2docx深度应用指南
Python库:【Tableau】气候数据可视化

Stata | 从字节串到Unicode:Stata ustrfrom使用手册

Seminar|CEO言行不一,审计师如何“明察秋毫”?——一项关于诚信、审计与公司治理的深度研究

《赌神》 里的发哥能赢赌场?蒙特卡洛模拟:现实里“赌神”赢不了这5.26%”

Python | 别让Emoji毁了你的模型!Python机器学习中的Emoji “神翻译”指南

Stata爬虫——我的数据去哪里了?

python爬虫 | 获取港股基本信息

Stata入门:tempvar命令与tempfile命令详解

Python绘图:用matplotlib库绘制好看的折线图

Seminar | 注意力独特性与企业绩效:增长行动的中介作用

LaTeX Beamer——值得了解的强大工具

Stata | 从sum2docx到reg2docx——基于《中国工业经济》期刊文章的结果输出

Seminar | 邻避效应:内在动机与企业污染治理

Stata爬取豆瓣读书,一键获取你的读书清单

Seminar | 自动化对企业报告质量的影响

识别处理重复值duplicates命令

Pandas 数据筛选的多种方法

Python交互可视化实战:构建动态数据仪表盘
关于我们 

   微信公众号“Stata and Python数据分析”分享实用的Stata、Python等软件的数据处理知识,欢迎转载、打赏。我们是由李春涛教授领导下的研究生及本科生组成的大数据处理和分析团队。

   我们团队一直为广大用户提供数据采集和分析的服务工作,如果您有这方面的需求,请发邮件到statatraining@163.com。

此外,欢迎大家踊跃投稿,介绍一些关于Stata和Python的数据处理和分析技巧。

投稿邮箱:statatraining@163.com投稿要求:1)必须原创,禁止抄袭;2)必须准确,详细,有例子,有截图;注意事项:1)所有投稿都会经过本公众号运营团队成员的审核,审核通过才可录用,一经录用,会在该推文里为作者署名,并有赏金分成。
2)邮件请注明投稿,邮件名称为“投稿+推文名称”。3)应广大读者要求,现开通有偿问答服务,如果大家遇到有关数据处理、分析等问题,可以在公众号中提出,只需支付少量赏金,我们会在后期的推文里给予解答。

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-07-03 17:58:16 HTTP/2.0 GET : https://f.mffb.com.cn/a/492231.html
  2. 运行时间 : 1.082661s [ 吞吐率:0.92req/s ] 内存消耗:4,631.16kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=112ede7e65452aa5538426d9307ee8d4
  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.000830s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.000882s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.079133s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.002555s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.000812s ]
  6. SELECT * FROM `set` [ RunTime:0.010619s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.000937s ]
  8. SELECT * FROM `article` WHERE `id` = 492231 LIMIT 1 [ RunTime:0.018043s ]
  9. UPDATE `article` SET `lasttime` = 1783072697 WHERE `id` = 492231 [ RunTime:0.012231s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 66 LIMIT 1 [ RunTime:0.002306s ]
  11. SELECT * FROM `article` WHERE `id` < 492231 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.010750s ]
  12. SELECT * FROM `article` WHERE `id` > 492231 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.081309s ]
  13. SELECT * FROM `article` WHERE `id` < 492231 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.116393s ]
  14. SELECT * FROM `article` WHERE `id` < 492231 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.414651s ]
  15. SELECT * FROM `article` WHERE `id` < 492231 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.256670s ]
1.085062s