当前位置:首页>python>生成遍历顺序对比说明文档 python代码

生成遍历顺序对比说明文档 python代码

  • 2026-07-02 16:36:37
生成遍历顺序对比说明文档 python代码

# -*- coding: utf-8 -*-

"""

生成遍历顺序对比说明文档 (docx)

"""

importos

importmatplotlib

matplotlib.use('Agg')

matplotlib.rcParams['font.sans-serif'= ['Microsoft YaHei''SimSun''KaiTi']

matplotlib.rcParams['axes.unicode_minus'=False

importmatplotlib.pyplotasplt

importmatplotlib.patchesasmpatches

frommatplotlib.patchesimportFancyBboxPatch

import numpy asnp

from docx import Document

from docx.shared import Inches, Pt, Cm, RGBColor

from docx.enum.text import WD_ALIGN_PARAGRAPH

from docx.enum.table import WD_TABLE_ALIGNMENT

# ========== 配置 ==========

ROWSCOLS=45

OUT_DIR=r'C:\Users\yl\Desktop'

IMG_DIR=os.path.join(OUT_DIR'_temp_imgs')

os.makedirs(IMG_DIRexist_ok=True)

# ========== 画图工具函数 ==========

defdraw_grid_with_arrows(axordertitlesubtitleorder_name

arrow_color='#E74C3C'cell_bg='#F0F3F4',

highlight_color='#FADBD8'text_color='#2C3E50'):

"""绘制带箭头和序号的网格图"""

ax.set_xlim(-0.1COLS-0.05)

ax.set_ylim(-0.1ROWS-0.05)

ax.set_aspect('equal')

ax.axis('off')

# 标题

ax.text(COLS/2ROWS+0.5titlefontsize=14fontweight='bold',

ha='center'va='center'color=text_color,

bbox=dict(boxstyle='round,pad=0.3'facecolor='#EBF5FB'alpha=0.8))

ax.text(COLS/2ROWS+0.15subtitlefontsize=10,

ha='center'va='center'color='#7F8C8D')

# 绘制单元格

forrinrange(ROWS):

forcinrange(COLS):

idx=order[rc]

# 根据顺序深浅着色

alpha=0.3+0.7* (idx/ (ROWS*COLS-1))

color=plt.cm.RdYlGn_r(alpha)

rect=FancyBboxPatch((cROWS-1-r), 11

boxstyle="square,pad=0",

facecolor=coloredgecolor='#BDC3C7',

linewidth=1.5)

ax.add_patch(rect)

# 序号文字

ax.text(c+0.5ROWS-1-r+0.5str(idx+1),

ha='center'va='center'fontsize=11fontweight='bold',

color='#2C3E50')

# 绘制箭头连线

order_list= []

forrinrange(ROWS):

forcinrange(COLS):

order_list.append((cROWS-1-r))

foriinrange(len(order_list-1):

x1y1=order_list[i]

x2y2=order_list[i+1]

ax.annotate(''xy=(x2+0.5y2+0.5), xytext=(x1+0.5y1+0.5),

arrowprops=dict(arrowstyle='->'color=arrow_color,

lw=1.5alpha=0.6))

# 添加顺序名称标签

ax.text(0.05-0.4f'→ {order_name}'fontsize=9fontweight='bold',

color=arrow_colortransform=ax.transData)

defdraw_comparison_grid(axordertitleorder_namearrow_color):

"""绘制对比图(两个网格并排中的单个)"""

ax.set_xlim(-0.1COLS-0.05)

ax.set_ylim(-0.1ROWS-0.05)

ax.set_aspect('equal')

ax.axis('off')

ax.text(COLS/2ROWS+0.3titlefontsize=11fontweight='bold',

ha='center'va='center'color='#2C3E50')

forrinrange(ROWS):

forcinrange(COLS):

idx=order[rc]

alpha=0.3+0.7* (idx/ (ROWS*COLS-1))

color=plt.cm.RdYlGn_r(alpha)

rect=FancyBboxPatch((cROWS-1-r), 11,

boxstyle="square,pad=0",

facecolor=coloredgecolor='#BDC3C7',

linewidth=1)

ax.add_patch(rect)

ax.text(c+0.5ROWS-1-r+0.5str(idx+1),

ha='center'va='center'fontsize=9fontweight='bold',

color='#2C3E50')

order_list= []

forrinrange(ROWS):

forcinrange(COLS):

order_list.append((cROWS-1-r))

foriinrange(len(order_list-1):

x1y1=order_list[i]

x2y2=order_list[i+1]

ax.annotate(''xy=(x2+0.5y2+0.5), xytext=(x1+0.5y1+0.5),

arrowprops=dict(arrowstyle='->'color=arrow_color,

lw=1alpha=0.5))

# ========== 生成图片 ==========

# 1. 从左到右,从上到下(行优先)

order_row=np.zeros((ROWSCOLS), dtype=int)

forrinrange(ROWS):

forcinrange(COLS):

order_row[rc=r*COLS+c

fig1ax1=plt.subplots(11figsize=(87), dpi=150)

draw_grid_with_arrows(ax1order_row

'方式一:从左到右 → 从上到下',

'(行优先 / Row-Major Order)',

'行优先遍历')

fig1.savefig(os.path.join(IMG_DIR'row_major.png'), bbox_inches='tight'pad_inches=0.3)

plt.close(fig1)

# 2. 从上到下,从左到右(列优先)

order_col=np.zeros((ROWSCOLS), dtype=int)

forcinrange(COLS):

forrinrange(ROWS):

order_col[rc=c*ROWS+r

fig2ax2=plt.subplots(11figsize=(87), dpi=150)

draw_grid_with_arrows(ax2order_col,

'方式二:从上到下 ↓ 从左到右',

'(列优先 / Column-Major Order)',

'列优先遍历',

arrow_color='#3498DB')

fig2.savefig(os.path.join(IMG_DIR'col_major.png'), bbox_inches='tight'pad_inches=0.3)

plt.close(fig2)

# 3. 对比图

fig3axes=plt.subplots(12figsize=(147), dpi=150)

draw_comparison_grid(axes[0], order_row,

'从左到右,从上到下\n(行优先)',

'行优先''#E74C3C')

draw_comparison_grid(axes[1], order_col,

'从上到下,从左到右\n(列优先)',

'列优先''#3498DB')

fig3.suptitle('两种遍历顺序对比'fontsize=16fontweight='bold'y=1.02)

fig3.savefig(os.path.join(IMG_DIR'comparison.png'), bbox_inches='tight'pad_inches=0.3)

plt.close(fig3)

# ========== 生成 Word 文档 ==========

doc= Document()

# 页面设置

forsectionindoc.sections:

section.page_width = Cm(21)

section.page_height = Cm(29.7)

section.left_margin = Cm(2.5)

section.right_margin = Cm(2.5)

section.top_margin = Cm(2)

section.bottom_margin = Cm(2)

# 标题

title=doc.add_heading('二维网格遍历顺序对比说明'level=0)

title.alignment = WD_ALIGN_PARAGRAPH.CENTER

doc.add_paragraph('')  # 空行

# ===== 一、概述 =====

doc.add_heading('一、概述'level=1)

p=doc.add_paragraph()

p.add_run('在二维网格(矩阵、栅格、图像像素等)中遍历所有单元格时,有两种最基本的遍历顺序:')

t=doc.add_table(rows=2cols=2)

t.style ='Light Grid Accent 1'

t.alignment = WD_TABLE_ALIGNMENT.CENTER

t.cell(00).text ='方式'

t.cell(01).text ='说明'

t.cell(10).text ='从左到右,从上到下'

t.cell(11).text ='先遍历完当前行的所有列,再换到下一行(行优先 / Row-Major)'

# 设置表格字体

forrowint.rows:

forcellinrow.cells:

forparagraphincell.paragraphs:

forruninparagraph.runs:

run.font.size = Pt(11)

doc.add_paragraph('')

# ===== 二、详细说明 =====

doc.add_heading('二、方式一:从左到右,从上到下(行优先)'level=1)

doc.add_paragraph('遍历规则:')

p=doc.add_paragraph('每一行内,从左向右依次访问每个单元格'style='List Bullet')

p=doc.add_paragraph('当前行访问完毕后,换到下一行,继续从左到右'style='List Bullet')

p=doc.add_paragraph('所有行从上到下依次处理'style='List Bullet')

doc.add_paragraph('访问顺序公式:')

p=doc.add_paragraph()

run=p.add_run('index = row × 列数 + col')

run.font.name ='Consolas'

run.font.size = Pt(11)

run.font.color.rgb = RGBColor(0x2C0x3E0x50)

doc.add_paragraph('')

doc.add_paragraph('图示:')

doc.add_picture(os.path.join(IMG_DIR'row_major.png'), width=Cm(16))

doc.add_paragraph('')

doc.add_heading('三、方式二:从上到下,从左到右(列优先)'level=1)

doc.add_paragraph('遍历规则:')

p=doc.add_paragraph('每一列内,从上向下依次访问每个单元格'style='List Bullet')

p=doc.add_paragraph('当前列访问完毕后,换到下一列,继续从上到下'style='List Bullet')

p=doc.add_paragraph('所有列从左到右依次处理'style='List Bullet')

doc.add_paragraph('访问顺序公式:')

p=doc.add_paragraph()

run=p.add_run('index = col × 行数 + row')

run.font.name ='Consolas'

run.font.size = Pt(11)

run.font.color.rgb = RGBColor(0x2C0x3E0x50)

doc.add_paragraph('')

doc.add_paragraph('图示:')

doc.add_picture(os.path.join(IMG_DIR'col_major.png'), width=Cm(16))

# ===== 四、对比 =====

doc.add_heading('四、对比总结'level=1)

doc.add_paragraph('')

doc.add_paragraph('两种遍历顺序的直观对比:')

doc.add_paragraph('')

doc.add_picture(os.path.join(IMG_DIR'comparison.png'), width=Cm(16))

doc.add_paragraph('')

# 对比表格

t2=doc.add_table(rows=6cols=3)

t2.style ='Light Grid Accent 1'

t2.alignment = WD_TABLE_ALIGNMENT.CENTER

headers= ['对比项''从左到右 → 从上到下(行优先)''从上到下 ↓ 从左到右(列优先)']

data= [

    ['遍历方向''行内水平移动为主''列内垂直移动为主'],

    ['内存访问''行内连续访问,缓存友好''列内跳跃访问,缓存不友好'],

    ['适用场景''C/C++/Python 数组、图像处理''Fortran/MATLAB 数组、GIS 栅格'],

    ['循环嵌套''外层 for row,内层 for col''外层 for col,内层 for row'],

    ['别名''Row-Major Order''Column-Major Order'],

]

forjhinenumerate(headers):

cell=t2.cell(0j)

cell.text =h

forpincell.paragraphs:

forruninp.runs:

run.font.bold =True

run.font.size = Pt(10)

forirow_datainenumerate(data):

forjvalinenumerate(row_data):

cell=t2.cell(i+1j)

cell.text =val

forpincell.paragraphs:

forruninp.runs:

run.font.size = Pt(10)

doc.add_paragraph('')

# ===== 五、示例代码 =====

doc.add_heading('五、代码示例'level=1)

doc.add_heading('5.1 行优先(从左到右,从上到下)'level=2)

code1="""# C / Python 风格 — 行优先

for row in range(ROWS):        # 外层:行(从上到下)

    for col in range(COLS):    # 内层:列(从左到右)

        visit(grid[row][col])

# 访问顺序:(0,0)→(0,1)→(0,2)→...→(1,0)→(1,1)→..."""

p=doc.add_paragraph()

run=p.add_run(code1)

run.font.name ='Consolas'

run.font.size = Pt(9)

run.font.color.rgb = RGBColor(0x2C0x3E0x50)

doc.add_heading('5.2 列优先(从上到下,从左到右)'level=2)

code2="""# 列优先遍历

for col in range(COLS):        # 外层:列(从左到右)

    for row in range(ROWS):    # 内层:行(从上到下)

        visit(grid[row][col])

# 访问顺序:(0,0)→(1,0)→(2,0)→...→(0,1)→(1,1)→..."""

p=doc.add_paragraph()

run=p.add_run(code2)

run.font.name ='Consolas'

run.font.size = Pt(9)

run.font.color.rgb = RGBColor(0x2C0x3E0x50)

# ===== 六、注意事项 =====

doc.add_heading('六、注意事项'level=1)

notes= [

'行优先是 C、C++、Python(NumPy 默认)等语言的数组存储方式',

'列优先是 Fortran、MATLAB、R 等语言的数组存储方式',

'在 GIS 栅格数据处理中,两种遍历方式都常见,需注意数据格式要求的存储顺序',

'行优先遍历时,相邻访问的内存地址连续,CPU 缓存命中率更高,性能通常更好',

'选择哪种遍历方式取决于具体应用场景和数据存储格式',

]

fornoteinnotes:

doc.add_paragraph(notestyle='List Bullet')

# 保存

out_path=os.path.join(OUT_DIR'遍历顺序对比说明_新.docx')

doc.save(out_path)

print(f'Document saved: {out_path}')

# 清理临时图片

importshutil

shutil.rmtree(IMG_DIR)

print('Temp images cleaned up.')

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-07-03 10:59:37 HTTP/2.0 GET : https://f.mffb.com.cn/a/495426.html
  2. 运行时间 : 0.132165s [ 吞吐率:7.57req/s ] 内存消耗:5,184.95kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=fe783a75701cef3e12e67d914e26fc88
  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.000752s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.000955s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.000357s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.000288s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.000628s ]
  6. SELECT * FROM `set` [ RunTime:0.000228s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.000722s ]
  8. SELECT * FROM `article` WHERE `id` = 495426 LIMIT 1 [ RunTime:0.001559s ]
  9. UPDATE `article` SET `lasttime` = 1783047577 WHERE `id` = 495426 [ RunTime:0.010630s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 66 LIMIT 1 [ RunTime:0.000402s ]
  11. SELECT * FROM `article` WHERE `id` < 495426 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.000896s ]
  12. SELECT * FROM `article` WHERE `id` > 495426 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.000516s ]
  13. SELECT * FROM `article` WHERE `id` < 495426 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.013145s ]
  14. SELECT * FROM `article` WHERE `id` < 495426 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.001202s ]
  15. SELECT * FROM `article` WHERE `id` < 495426 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.005346s ]
0.134916s