当前位置:首页>python>《码上仿真:Abaqus Python API》Vol.18 AFXToolsetGui Abaqus 界面大整容(上)

《码上仿真:Abaqus Python API》Vol.18 AFXToolsetGui Abaqus 界面大整容(上)

  • 2026-06-30 02:21:59
《码上仿真:Abaqus Python API》Vol.18 AFXToolsetGui Abaqus 界面大整容(上)

如果说之前的 Python 建模脚本是你在实验室里穿着白大褂捣鼓出的"核心科技",那么 GUI(图形用户界面)二次开发就是给这项科技穿上了一套得体的"西装",让它能够走出实验室,走向生产一线。

在工程实践中,一个能够运行的脚本和一个能够被广泛使用的工具之间,往往只差一个友好的界面。想象一下这样的场景:你花费数周开发了一套高效的自动化建模脚本,能够一键完成复杂结构的参数化建模、网格划分和作业提交。但当你的同事想要使用时,却发现自己必须打开代码编辑器、修改参数、在命令行中运行——这对于不熟悉 Python 的工程师来说无疑是一道门槛。

GUI 的价值就在于此:它把技术细节封装在直观的界面元素背后,让用户通过点击按钮、填写表单、选择选项就能完成复杂的操作。一个好的 GUI 不仅降低了使用门槛,还能减少人为错误,提高工作效率。

Abaqus GUI 开发生态概览

在 Abaqus 的二次开发生态里,AFXToolsetGui 是所有自定义工具箱的"始祖"。通过继承这个类,你可以把凌乱的脚本封装成一个个精美的图标,集成到 Abaqus/CAE 的主界面中。

Abaqus 的 GUI 框架基于以下几个核心组件:

1. AFXToolsetGui:工具箱基类,定义自定义工具集的容器

2. AFXGuiCommand:GUI 命令类,关联界面操作与内核脚本

3. AFXMode:模式类,管理复杂的对话框交互流程

4. Fox Toolkit:底层 GUI 工具包,提供按钮、文本框、下拉菜单等控件

这种分层架构使得开发者可以在不同抽象层次上进行开发:既可以直接使用 Fox Toolkit 构建精细的界面,也可以通过 AFX 类快速搭建标准界面。

界面开发不仅仅是画图,更是一场严密的逻辑架构。一个完整的 GUI 插件需要协调界面显示、用户交互、内核通讯等多个方面。今天,我们就来学习如何拆掉官方界面的"围墙",盖起属于你自己的"功能房"。

1. 继承的力量:AFXToolsetGui 类

在 abaqusGui 模块中,你需要创建一个新类,并继承自 AFXToolsetGui。

from abaqusGui import *class MyCustomToolset(AFXToolsetGui):    """    自定义工具箱类    继承自 AFXToolsetGui,获得 Abaqus GUI 框架支持    """    def __init__(self):        # 调用父类构造函数,指定工具箱名称        AFXToolsetGui.__init__(self, 'My Custom Tools')        # 在这里添加自定义控件...

这就像是参加一场名为"Abaqus 选秀"的比赛。AFXToolsetGui 就是官方给你的"选手模版"。你继承了它,就自动获得了进入 Abaqus 主界面的"入场券",你的工具箱(Toolset)从此就有了名分,不再是法外之地。

继承带来的能力

  • 自动注册:工具箱自动出现在 Abaqus/CAE 的插件菜单中

  • 生命周期管理:框架自动处理工具箱的创建、显示和销毁

  • 消息路由:内置的消息机制处理用户交互事件

  • 资源管理:自动加载图标、帮助文档等资源文件

2. 占领领地:工具箱(Toolbox)与菜单栏

通过 `getAFXApp().getAFXMainWindow().getToolbox()` 获取工具箱对象,然后使用 AFXGuiCommand 关联你的脚本。

def register_toolset():    """    注册工具箱到 Abaqus 主界面    """    # 获取主窗口对象    main_window = getAFXApp().getAFXMainWindow()    # 获取工具箱对象(左侧图标栏)    toolbox = main_window.getToolbox()    # 创建工具箱实例    my_toolset = MyCustomToolset()    # 将工具箱添加到界面    toolbox.addToolset(my_toolset)    # 也可以添加到菜单栏    menu_bar = main_window.getMenuBar()    # ... 菜单添加代码 ...

Abaqus 的界面就像是一个黄金地段的商场。

  • 菜单栏(Menu Bar)是商场顶层的指示牌。它位于窗口顶部,以文字形式组织功能,适合放置不常用但重要的操作,如"文件"、"编辑"、"视图"、"工具"等。菜单栏的优势在于可以容纳大量功能,且层级清晰,适合专业用户快速定位。

  • 工具箱(Toolbox)是商场一楼的精品柜台(左侧那一排图标)。它以图标形式展示常用功能,直观且易于点击。工具箱适合放置高频操作,如"一键网格划分"、"快速报告生成"等。图标的设计直接影响用户的第一印象,因此需要精心设计。

  • 工具栏(Toolbar)是商场中部的促销展台。它通常位于菜单栏下方,以图标+文字的形式展示功能,介于菜单栏和工具箱之间。

你的任务就是用脚本在这些柜台上摆上你的"独家产品"。你可以自定义图标(Icon),让用户一眼就能认出这是你的"黑科技"。

3. 跨界通讯:GUI 与 Kernel 的"密电"

GUI 侧运行在自己的 Python 解释器中,它不认识 mdb。它必须通过 sendCommandString 或 Mode(模式)将命令发送给内核侧。

class MyGuiCommand(AFXGuiCommand):    """    GUI 命令类    负责收集用户输入并发送给内核执行    """    def __init__(self, form):        AFXGuiCommand.__init__(self, form)    def doCustomChecks(self):        """        执行前的自定义检查        """        # 验证用户输入...        return True    def issueCommand(self):        """        发送命令到内核        """        # 构建命令字符串        cmd = f"create_model(width={self.form.width}, height={self.form.height})"        # 发送给内核执行        self.sendCommandString(cmd)

这就像是"前台(GUI)"与"后厨(Kernel)"的关系。前台负责貌美如花、接待客人(收集参数),然后写一张"小票(命令字符串)"传给后厨。后厨接到小票后,才开始真正挥锅铲、算矩阵。这种解耦设计保证了即便界面卡住了,计算依然能稳步进行。

4.实战代码:创建你的第一个"自定义按钮"

在 GUI 开发中,脚本风格与建模截然不同。以下是一个完整的自定义工具箱开发示例:

from abaqusGui import *# 1. 定义你的工具箱类class MySamsaraToolset(AFXToolsetGui):    def __init__(self):        # 显式调用父类构造函数        AFXToolsetGui.__init__(self, 'My Custom Tools')        # 2. 获取图标(假设你有一个 bmp 文件)        icon = afxCreateIcon('my_icon.bmp')        # 3. 创建一个按钮并放进工具栏        # 当点击按钮时,它会向内核发送一串 Python 代码        FXButton(p=self, text='Run Simulation', ic=icon,                  tgt=self, sel=AFX_ID_COMMAND)# 4. 注册并显示工具箱(这部分通常在 module 定义中完成)

完整工程案例:参数化建模工具箱

from abaqusGui import *from abaqusConstants import *class ParametricModelingToolset(AFXToolsetGui):    """    参数化建模工具箱    提供快速创建标准结构的功能    """    def __init__(self):        # 调用父类构造函数        AFXToolsetGui.__init__(self, 'Parametric Modeling')        # 创建表单(Form)用于存储用户输入        self.form = ParametricForm()        # 创建工具箱按钮        self.create_toolbox_buttons()    def create_toolbox_buttons(self):        """        创建工具箱按钮        """        # 加载图标        icon_beam = afxCreateIcon('beam_icon.png')        icon_plate = afxCreateIcon('plate_icon.png')        icon_report = afxCreateIcon('report_icon.png')        # 创建按钮组        group = FXGroupBox(self, 'Quick Modeling', FRAME_GROOVE)        # 梁结构按钮        btn_beam = FXButton(            p=group,            text='Create Beam',            ic=icon_beam,            tgt=BeamCommand(self.form),            sel=AFXMode.ID_ACTIVATE        )        btn_beam.setTipText('Create parametric beam structure')        # 板结构按钮        btn_plate = FXButton(            p=group,            text='Create Plate',            ic=icon_plate,            tgt=PlateCommand(self.form),            sel=AFXMode.ID_ACTIVATE        )        btn_plate.setTipText('Create parametric plate structure')        # 报告生成按钮        btn_report = FXButton(            p=group,            text='Generate Report',            ic=icon_report,            tgt=ReportCommand(self.form),            sel=AFXMode.ID_ACTIVATE        )        btn_report.setTipText('Generate analysis report')class ParametricForm(AFXForm):    """    参数表单类    存储和管理用户输入的参数    """    def __init__(self):        AFXForm.__init__(self)        # 定义参数        self.width = AFXFloatKeyword(            self, 'width', TRUE, 100.0        )        self.height = AFXFloatKeyword(            self, 'height', TRUE, 50.0        )        self.length = AFXFloatKeyword(            self, 'length', TRUE, 200.0        )        self.material = AFXStringKeyword(            self, 'material', TRUE, 'Steel'        )class BeamCommand(AFXGuiCommand):    """    梁结构创建命令    """    def __init__(self, form):        AFXGuiCommand.__init__(self, form)        self.form = form    def issueCommand(self):        """        发送命令到内核创建梁结构        """        cmd = f"""from abaqus import *from abaqusConstants import *# 创建梁模型model = mdb.Model(name='Beam-Model')# 创建草图sketch = model.ConstrainedSketch(name='Beam-Profile', sheetSize=200.0)sketch.rectangle(point1=(0, 0), point2=({self.form.width.getValue()}, {self.form.height.getValue()}))# 拉伸成实体part = model.Part(name='Beam', dimensionality=THREE_D, type=DEFORMABLE_BODY)part.BaseSolidExtrude(sketch=sketch, depth={self.form.length.getValue()})print('Beam created successfully!')"""        self.sendCommandString(cmd)class PlateCommand(AFXGuiCommand):    """    板结构创建命令    """    def __init__(self, form):        AFXGuiCommand.__init__(self, form)        self.form = form    def issueCommand(self):        """        发送命令到内核创建板结构        """        cmd = f"""from abaqus import *from abaqusConstants import *# 创建板模型model = mdb.Model(name='Plate-Model')# 创建草图sketch = model.ConstrainedSketch(name='Plate-Profile', sheetSize=500.0)sketch.rectangle(point1=(0, 0), point2=({self.form.width.getValue()}, {self.form.length.getValue()}))# 拉伸成薄板part = model.Part(name='Plate', dimensionality=THREE_D, type=DEFORMABLE_BODY)part.BaseSolidExtrude(sketch=sketch, depth={self.form.height.getValue()})print('Plate created successfully!')"""        self.sendCommandString(cmd)# 工具箱注册函数def register_parametric_toolset():    """    注册参数化建模工具箱到 Abaqus    """    # 获取主窗口    main_window = getAFXApp().getAFXMainWindow()    # 获取工具箱    toolbox = main_window.getToolbox()    # 创建并添加工具箱    toolset = ParametricModelingToolset()    toolbox.addToolset(toolset)    print("Parametric Modeling Toolset registered successfully!")# 在 Abaqus 启动时自动注册register_parametric_toolset()

注意事项

  • GUI 开发使用的是 Fox Toolkit 框架的包装版,语法更偏向传统的 C++/Object-Oriented 风格。这与内核脚本的过程式编程风格有很大不同,需要适应面向对象的思维方式。

  • 图标文件一定要是标准的 .bmp 或 .png 格式,尺寸建议为 24x24 像素,否则界面会变得奇丑无比!图标设计应遵循简洁明了的原则,避免过于复杂的图案。

  • 资源文件组织:建议将图标、帮助文档等资源放在插件目录的 `res` 或 `icons` 子目录中,便于管理和分发。

  • 错误处理:GUI 代码应包含完善的错误处理机制,避免界面崩溃影响用户体验。

总结

在 Abaqus 脚本建模中,AFXToolsetGui 是工程师向开发者进化的标志。

GUI 开发的工程价值

1. 降低使用门槛:让非编程背景的工程师也能使用自动化工具

2. 提高工作效率:通过直观的界面减少操作时间和错误率

3. 标准化流程:确保分析流程的一致性和可重复性

4. 知识传承:将专家经验封装在工具中,便于团队共享

5. 品牌形象:定制化的界面体现专业性和技术实力

它要求你不仅要懂力学,还要懂用户体验(UX)。当你不再满足于代码能跑通,而是开始思考"用户点哪里最顺手"、"这个图标够不够直观"、"错误提示是否友好"时,你已经从一个单纯的"算题人",转变成了工业软件的"定义者"。这种掌控感,才是二次开发最迷人的地方。


👉互动话题:如果你能给 Abaqus 界面加一个"一键搞定"的按钮,你希望它是什么功能?是一键网格划分?还是一键生成精美报告?评论区大声说出你的梦想!

公众号

知识星球

扫码关注

科趣范,让科研更简单

小红书

抖音

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-07-04 11:05:14 HTTP/2.0 GET : https://f.mffb.com.cn/a/490053.html
  2. 运行时间 : 0.119302s [ 吞吐率:8.38req/s ] 内存消耗:4,680.21kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=9ac7b2c498e82499fdefe2ca578c876a
  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.000645s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.000700s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.001861s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.004337s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.000558s ]
  6. SELECT * FROM `set` [ RunTime:0.000790s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.000585s ]
  8. SELECT * FROM `article` WHERE `id` = 490053 LIMIT 1 [ RunTime:0.001579s ]
  9. UPDATE `article` SET `lasttime` = 1783134314 WHERE `id` = 490053 [ RunTime:0.003627s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 66 LIMIT 1 [ RunTime:0.000281s ]
  11. SELECT * FROM `article` WHERE `id` < 490053 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.000427s ]
  12. SELECT * FROM `article` WHERE `id` > 490053 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.003487s ]
  13. SELECT * FROM `article` WHERE `id` < 490053 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.010971s ]
  14. SELECT * FROM `article` WHERE `id` < 490053 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.015591s ]
  15. SELECT * FROM `article` WHERE `id` < 490053 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.001777s ]
0.120896s