当前位置:首页>python>Python Tkinter 定制快捷键操作:让你的桌面应用"听话"起来

Python Tkinter 定制快捷键操作:让你的桌面应用"听话"起来

  • 2026-07-04 02:30:01
Python Tkinter 定制快捷键操作:让你的桌面应用"听话"起来

🎬 从一个真实的抓狂瞬间说起

你有没有遇到过这种情况——给客户演示一个内部工具,界面挺好看,功能也跑通了,结果客户问了一句:"这个能按 Ctrl+S 保存吗?"

你愣了一秒。

然后笑着说:"当然可以,下次迭代加上。"

其实心里清楚:你根本没想过这件事。

快捷键这个东西,说起来不起眼,但用户一旦习惯了,没有它就像打字少了空格键——哪儿哪儿都别扭。Tkinter 作为 Python 内置的 GUI 框架,快捷键绑定的能力其实相当完整,但文档写得像说明书,很多人看完还是不知道从哪下手。

这篇文章,咱们就把这块儿彻底搞清楚。从基础绑定到组合键、从全局监听到动态修改,每个环节都有可以直接跑的代码。


🧠 先搞懂 Tkinter 的事件机制

很多人上来就 bind,结果绑了半天没反应,或者只有某个控件触发,其他地方不管用。

根本原因是没理解 Tkinter 的事件传播链

Tkinter 的事件系统是基于 X Window 系统设计的,即便在 Windows 上,底层逻辑也遵循这个模型。每个事件从触发的控件开始,沿着 widget 树向上冒泡。绑定可以发生在三个层级:

  • • widget 级别:只对这个控件生效
  • • class 级别:对同类控件生效(较少用)
  • • 全局级别:绑定到根窗口 root,理论上对整个应用生效

但这里有个坑。绑定到 root 并不等于"全局生效"——如果焦点在某个子控件上,事件会先被子控件处理,只有在子控件没有绑定的情况下才会冒泡到 root。

这就解释了为什么很多人绑了 root.bind('<Control-s>', ...) 之后,一旦点击了 Text 或 Entry 控件,快捷键就"失灵"了。

解决思路有两个:一是在每个需要响应的子控件上也绑定;二是用 bind_all,它会让事件绑定穿透所有层级。


🔑 基础快捷键绑定:三种写法,各有用途

写法一:标准 bind

import tkinter as tk

defsave_file(event=None):
print("文件已保存")

root = tk.Tk()
root.title("快捷键演示")
root.geometry("400x300")

# 绑定到根窗口
root.bind('<Control-s>', save_file)

root.mainloop()

注意函数签名里的 event=None——这不是可选的,是必须的。bind 触发时会把事件对象传进来,如果函数不接收这个参数,运行时直接报错。加上 =None 是为了让这个函数也能被按钮的 command 直接调用(那时候不传 event)。

写法二:bind_all 全局绑定

root.bind_all('<Control-s>', save_file)

这一行的效果是:不管焦点在哪个控件上,按下 Ctrl+S 都会触发。适合全局性的操作,比如保存、撤销、退出。

但要小心——Text 控件自带了一些内置绑定(比如 Ctrl+A 全选),bind_all 有时候会和它们冲突。后面会专门说怎么处理。

写法三:菜单快捷键(accelerator)

menu_bar = tk.Menu(root)
file_menu = tk.Menu(menu_bar, tearoff=0)

file_menu.add_command(
    label="保存",
    accelerator="Ctrl+S",
    command=save_file
)

menu_bar.add_cascade(label="文件", menu=file_menu)
root.config(menu=menu_bar)

# 注意:accelerator 只是显示用,实际绑定还是要手动写
root.bind('<Control-s>', save_file)

这里有个让无数人踩坑的地方:accelerator 参数只是在菜单项旁边显示快捷键提示,它本身不会真的绑定任何键盘事件。你还是得手动 bind。Tkinter 这个设计确实有点反人类,但就是这样。


⌨️ 组合键与特殊键:事件字符串怎么写

Tkinter 的事件字符串格式是 <modifier-modifier-key>,用尖括号包裹。

常用修饰键:

修饰符
说明
Control
Ctrl 键
Alt
Alt 键
Shift
Shift 键
Meta
 / Command
Mac 的 Command 键

常用特殊键:

<Return>       # 回车
<Escape>       # Esc
<Tab>          # Tab
<BackSpace>    # 退格
<Delete>       # Delete
<F1> ~ <F12>  # 功能键
<Up> <Down> <Left> <Right>  # 方向键

组合示例:

root.bind('<Control-z>', undo_action)       # Ctrl+Z
root.bind('<Control-Shift-z>', redo_action) # Ctrl+Shift+Z
root.bind('<Alt-F4>', quit_app)             # Alt+F4
root.bind('<F5>', refresh_view)             # F5
root.bind('<Control-Alt-t>', open_terminal) # Ctrl+Alt+T

有一个细节:字母键区分大小写,但修饰键不区分。<Control-s> 和 <Control-S> 在 Windows 上通常都能触发,但为了保险,推荐统一用小写字母。


🏗️ 实战:构建一个带完整快捷键的文本编辑器

光说不练假把式。咱们来搭一个真实可用的小型文本编辑器,把常用快捷键全部实现进去。

import tkinter as tk
from tkinter import filedialog, messagebox
import os

classSimpleEditor:
def__init__(self):
self.root = tk.Tk()
self.root.title("SimpleEditor - 未命名")
self.root.geometry("800x600")

self.current_file = None
self.is_modified = False

self._build_ui()
self._bind_shortcuts()

def_build_ui(self):
# 菜单栏
        menubar = tk.Menu(self.root)

        file_menu = tk.Menu(menubar, tearoff=0)
        file_menu.add_command(label="新建", accelerator="Ctrl+N", command=self.new_file)
        file_menu.add_command(label="打开", accelerator="Ctrl+O", command=self.open_file)
        file_menu.add_command(label="保存", accelerator="Ctrl+S", command=self.save_file)
        file_menu.add_command(label="另存为", accelerator="Ctrl+Shift+S", command=self.save_as)
        file_menu.add_separator()
        file_menu.add_command(label="退出", accelerator="Ctrl+Q", command=self.quit_app)
        menubar.add_cascade(label="文件", menu=file_menu)

        edit_menu = tk.Menu(menubar, tearoff=0)
        edit_menu.add_command(label="全选", accelerator="Ctrl+A", command=self.select_all)
        edit_menu.add_command(label="查找", accelerator="Ctrl+F", command=self.find_text)
        menubar.add_cascade(label="编辑", menu=edit_menu)

self.root.config(menu=menubar)

# 工具栏状态提示
self.status_var = tk.StringVar(value="就绪")
        status_bar = tk.Label(
self.root, 
            textvariable=self.status_var,
            bd=1, relief=tk.SUNKEN, anchor=tk.W
        )
        status_bar.pack(side=tk.BOTTOM, fill=tk.X)

# 文本区域
        frame = tk.Frame(self.root)
        frame.pack(fill=tk.BOTH, expand=True)

self.text = tk.Text(frame, wrap=tk.WORD, undo=True, font=("Consolas"12))
        scrollbar = tk.Scrollbar(frame, command=self.text.yview)
self.text.configure(yscrollcommand=scrollbar.set)

        scrollbar.pack(side=tk.RIGHT, fill=tk.Y)
self.text.pack(side=tk.LEFT, fill=tk.BOTH, expand=True)

# 监听内容变化
self.text.bind('<<Modified>>'self._on_modified)

def_bind_shortcuts(self):
"""集中管理所有快捷键绑定"""
        shortcuts = {
'<Control-n>'self.new_file,
'<Control-o>'self.open_file,
'<Control-s>'self.save_file,
'<Control-S>'self.save_as,      # Ctrl+Shift+S
'<Control-q>'self.quit_app,
'<Control-f>'self.find_text,
'<Control-a>'self.select_all,
'<F5>'self.insert_timestamp,
        }

for key, func in shortcuts.items():
# 同时绑定到 root 和 text,避免焦点问题
self.root.bind(key, lambda e, f=func: f())
self.text.bind(key, lambda e, f=func: (f(), 'break'))
# 返回 'break' 阻止事件继续传播,防止与内置行为冲突

defnew_file(self):
ifself.is_modified:
ifnot messagebox.askyesno("提示""文件未保存,确定新建?"):
return
self.text.delete(1.0, tk.END)
self.current_file = None
self.is_modified = False
self.root.title("SimpleEditor - 未命名")
self.status_var.set("新建文件")

defopen_file(self):
        path = filedialog.askopenfilename(
            filetypes=[("文本文件""*.txt"), ("Python文件""*.py"), ("所有文件""*.*")]
        )
if path:
withopen(path, 'r', encoding='utf-8'as f:
                content = f.read()
self.text.delete(1.0, tk.END)
self.text.insert(1.0, content)
self.current_file = path
self.is_modified = False
self.root.title(f"SimpleEditor - {os.path.basename(path)}")
self.status_var.set(f"已打开: {path}")

defsave_file(self):
ifself.current_file:
withopen(self.current_file, 'w', encoding='utf-8'as f:
                f.write(self.text.get(1.0, tk.END))
self.is_modified = False
self.status_var.set(f"已保存: {self.current_file}")
else:
self.save_as()

defsave_as(self):
        path = filedialog.asksaveasfilename(
            defaultextension=".txt",
            filetypes=[("文本文件""*.txt"), ("Python文件""*.py"), ("所有文件""*.*")]
        )
if path:
self.current_file = path
self.save_file()
self.root.title(f"SimpleEditor - {os.path.basename(path)}")

defselect_all(self):
self.text.tag_add(tk.SEL, "1.0", tk.END)
self.text.mark_set(tk.INSERT, "1.0")
self.text.see(tk.INSERT)

deffind_text(self):
"""简单查找对话框"""
        dialog = tk.Toplevel(self.root)
        dialog.title("查找")
        dialog.geometry("300x80")
        dialog.resizable(FalseFalse)

        tk.Label(dialog, text="查找内容:").pack(side=tk.LEFT, padx=5)
        entry = tk.Entry(dialog, width=20)
        entry.pack(side=tk.LEFT, padx=5)
        entry.focus()

defdo_find():
            keyword = entry.get()
ifnot keyword:
return
# 清除之前的高亮
self.text.tag_remove('found''1.0', tk.END)
            start = '1.0'
            count = 0
whileTrue:
                pos = self.text.search(keyword, start, stopindex=tk.END)
ifnot pos:
break
                end = f"{pos}+{len(keyword)}c"
self.text.tag_add('found', pos, end)
self.text.tag_config('found', background='yellow', foreground='black')
                start = end
                count += 1
self.status_var.set(f"找到 {count} 处匹配")

        tk.Button(dialog, text="查找", command=do_find).pack(side=tk.LEFT, padx=5)
        dialog.bind('<Return>'lambda e: do_find())
        dialog.bind('<Escape>'lambda e: dialog.destroy())

definsert_timestamp(self):
"""F5 插入当前时间戳,类似 Notepad++"""
from datetime import datetime
        ts = datetime.now().strftime("%Y-%m-%d %H:%M:%S")
self.text.insert(tk.INSERT, ts)

defquit_app(self):
ifself.is_modified:
ifnot messagebox.askyesno("提示""文件未保存,确定退出?"):
return
self.root.quit()

def_on_modified(self, event):
ifself.text.edit_modified():
self.is_modified = True
            title = self.root.title()
ifnot title.startswith("*"):
self.root.title("*" + title)
self.text.edit_modified(False)

defrun(self):
self.root.mainloop()

if __name__ == "__main__":
    app = SimpleEditor()
    app.run()

这段代码可以直接跑。几个值得关注的设计点:

_bind_shortcuts 方法把所有快捷键集中管理,不散落在各处——这是维护性的关键。三个月后你回来改代码,一眼就能看到所有绑定关系。

lambda e, f=func: (f(), 'break') 这个写法稍微绕一点,但很重要。'break' 是 Tkinter 的特殊返回值,告诉事件系统"到此为止,别再往上传了"。对 Text 控件尤其关键,否则 Ctrl+A 会触发你的全选逻辑,同时也触发 Text 的内置全选,导致行为异常。


🔄 动态修改快捷键:运行时重新绑定

有些应用需要让用户自定义快捷键。这在 Tkinter 里完全可以实现——用 unbind 解绑旧的,再 bind 绑新的。

classHotkeyManager:
"""快捷键管理器,支持运行时动态修改"""

def__init__(self, root):
self.root = root
self.bindings = {}  # 存储 {action_name: (key, callback)}

defregister(self, action_name, key, callback):
"""注册或更新一个快捷键"""
# 如果已有绑定,先解绑旧的
if action_name inself.bindings:
            old_key = self.bindings[action_name][0]
self.root.unbind(old_key)

self.root.bind(key, callback)
self.bindings[action_name] = (key, callback)
print(f"快捷键已注册: {action_name} -> {key}")

defunregister(self, action_name):
"""取消注册"""
if action_name inself.bindings:
            key = self.bindings[action_name][0]
self.root.unbind(key)
delself.bindings[action_name]

defget_all(self):
"""获取所有当前绑定"""
return {name: key for name, (key, _) inself.bindings.items()}


# 使用示例
root = tk.Tk()
manager = HotkeyManager(root)

manager.register("save""<Control-s>"lambda e: print("保存"))
manager.register("open""<Control-o>"lambda e: print("打开"))

# 用户在设置里改了保存快捷键
manager.register("save""<Control-w>"lambda e: print("保存(新键位)"))

print(manager.get_all())
root.mainloop()

这个 HotkeyManager 的核心价值在于状态追踪。Tkinter 本身不提供"查询当前绑定了什么"的接口,所以你需要自己维护这个状态字典。


⚠️ 三个必须知道的坑

坑一:焦点丢失导致快捷键失效。 前面说过了,root.bind 在焦点转移到子控件后可能失效。除了用 bind_all,还有一个方案是给 Toplevel 窗口单独绑定——因为弹出窗口会独立接管焦点。

坑二:Windows 系统级快捷键的冲突。 Alt+F4 是系统关闭窗口的快捷键。如果你绑定了它,需要在回调里显式处理,否则系统行为和你的逻辑都会触发。Ctrl+Alt+Del 这类系统级别的就别想了,Tkinter 拦不住。

坑三:lambda 的闭包陷阱。 这是 Python 的老问题,在循环里创建 lambda 时特别容易出错:

# 错误写法——所有快捷键都会执行最后一个 action
actions = ['new''open''save']
for action in actions:
    root.bind(f'<Control-{action[0]}>'lambda e: print(action))  # 全是 'save'

# 正确写法——用默认参数捕获当前值
for action in actions:
    root.bind(f'<Control-{action[0]}>'lambda e, a=action: print(a))

这个坑我自己也踩过,调了一个小时才发现原来是闭包的问题。


💡 三句话技术洞察

快捷键不是锦上添花,是用户信任感的底层基础设施。

bind 和 bind_all 的选择,本质上是"局部控制"和"全局一致性"的权衡。

把所有快捷键集中到一个方法里管理,是代码可维护性的最低成本投资。


🧩 可复用代码模板

这是一个可以直接粘进项目的快捷键配置模板,适合任何 Tkinter 应用:

SHORTCUT_MAP = {
'<Control-n>': ('新建', new_file),
'<Control-o>': ('打开', open_file),
'<Control-s>': ('保存', save_file),
'<Control-z>': ('撤销', undo),
'<Control-y>': ('重做', redo),
'<Control-f>': ('查找', find),
'<Escape>':    ('关闭对话框', close_dialog),
'<F1>':        ('帮助', show_help),
}

for key, (desc, func) in SHORTCUT_MAP.items():
    root.bind_all(key, lambda e, f=func: f())

字典驱动的好处是:增删改快捷键只需要改配置,不用到处找 bind 调用。


📌 写在最后

Tkinter 的快捷键机制并不复杂,但细节很多。从基础 bind 到 bind_all,从静态配置到动态管理,每一层都有对应的适用场景。

我在项目里见过最常见的问题,不是"不会用",而是"用了但不生效"——九成九是焦点问题和事件冒泡没处理好。把本文的 'break' 返回值和集中绑定策略用起来,大部分坑就绕过去了。

完整源码已整理好,可在 GitHub 搜索 tkinter-shortkey-demo 获取。欢迎在评论区聊聊你在 Tkinter 项目里遇到的奇葩快捷键问题——有些坑,说出来大家一起笑一笑,下次就不踩了。


标签PythonTkinterGUI开发快捷键桌面应用

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-07-04 02:43:00 HTTP/2.0 GET : https://f.mffb.com.cn/a/486704.html
  2. 运行时间 : 0.155822s [ 吞吐率:6.42req/s ] 内存消耗:4,985.14kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=cff556aba8f221a141c89ca19a8fc9f8
  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.000620s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.000810s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.000373s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.000338s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.000736s ]
  6. SELECT * FROM `set` [ RunTime:0.000246s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.000632s ]
  8. SELECT * FROM `article` WHERE `id` = 486704 LIMIT 1 [ RunTime:0.025340s ]
  9. UPDATE `article` SET `lasttime` = 1783104180 WHERE `id` = 486704 [ RunTime:0.017111s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 66 LIMIT 1 [ RunTime:0.000577s ]
  11. SELECT * FROM `article` WHERE `id` < 486704 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.005640s ]
  12. SELECT * FROM `article` WHERE `id` > 486704 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.010665s ]
  13. SELECT * FROM `article` WHERE `id` < 486704 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.002834s ]
  14. SELECT * FROM `article` WHERE `id` < 486704 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.000962s ]
  15. SELECT * FROM `article` WHERE `id` < 486704 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.016117s ]
0.158582s