用 Python 30 分钟做出自己的记事本


🌟 《零基础手把手:用 Python 30 分钟做出自己的记事本》

—— 不是照抄代码,而是理解每行代码的「灵魂」


🧩 第一步:为什么我们需要「基础窗口」?(新手必懂!)

❌ 常见错误:直接写 window.show() 但窗口不显示?

✅ 正确逻辑:程序运行流程图

启动程序

创建应用对象

创建窗口

显示窗口

进入事件循环

📝 代码详解(逐行解释):

import sys # 必须!用于接收系统参数(比如文件路径)from PyQt6.QtWidgets import QApplication, QMainWindow # 从PyQt库导入两个核心组件# 1️⃣ 创建应用对象(灵魂!所有PyQt程序必须有) app = QApplication(sys.argv)# sys.argv = 系统传递的命令行参数(比如打开的文件名)# 2️⃣ 创建主窗口(你的「画布」) window = QMainWindow()# 100% 会用到的窗口类型 window.setWindowTitle("我的迷你记事本")# 设置标题(为什么叫"窗口"?因为它是所有UI的容器!) window.resize(500,400)# 设置大小(宽500px, 高400px)# 3️⃣ 显示窗口(关键!) window.show()# ✨ 为什么必须写?因为窗口默认是「隐形」的!# ❌ 如果不写这行,程序会直接结束,你永远看不到窗口!# 4️⃣ 进入事件循环(让程序「活」起来) sys.exit(app.exec())# ✨ 为什么叫「事件循环」?因为程序会一直监听用户操作(点击、输入等)

💡 思考题

❓ 如果我删掉 sys.exit(app.exec()) 会怎样?
答案:程序会立刻结束!你只能看到一闪而过的窗口(就像打开一个网页立刻关闭)。

🧩 第二步:为什么需要 QTextEdit?(小白必看!)

❌ 常见错误:用 QLineEdit(单行输入框)做记事本 → 无法输入多行文字!

✅ 正确选择:QTextEdit = 专为多行文本设计的编辑器

📝 代码详解(添加编辑器):

from PyQt6.QtWidgets import QApplication, QMainWindow, QTextEdit # 新增导入 app = QApplication(sys.argv) window = QMainWindow() window.setWindowTitle("我的迷你记事本") window.resize(700,500)# 宽高调大一点(记事本需要更多空间)# ✨ 关键步骤:把编辑器设置为窗口的「中央内容」 editor = QTextEdit()# 创建编辑器对象 window.setCentralWidget(editor)# 设置为窗口的主区域# ✨ 为什么叫「中央」?因为窗口可以有顶部菜单、底部状态栏,编辑器占中间大块

💡 思考题

❓ 如果我把 window.setCentralWidget(editor) 写成 window.setWidget(editor) 会怎样?
答案:报错!setCentralWidget 是 QMainWindow 的专属方法(PyQt 设计的规范)。

🧩 第三步:菜单栏怎么设计?(不是复制粘贴!)

❌ 常见错误:直接写 menubar = menuBar() → 无菜单!

✅ 正确逻辑:菜单 = 1个主菜单 + 多个子菜单项

📝 代码详解(分步构建菜单):

# 1️⃣ 创建菜单栏(必须先有窗口才有菜单栏) menubar = window.menuBar()# 获取窗口的菜单栏对象# 2️⃣ 添加「文件」主菜单(为什么叫「主菜单」?因为它在最左边) file_menu = menubar.addMenu("文件")# 创建菜单项# 3️⃣ 在「文件」里添加子菜单(每个子菜单是用户点击的按钮) open_action = file_menu.addAction("打开文件")# 添加「打开」按钮 save_action = file_menu.addAction("保存文件")# 添加「保存」按钮# 4️⃣ 设置快捷键(为什么需要?因为用户习惯Ctrl+S!) save_action.setShortcut("Ctrl+S")# 40% 用户会用快捷键

💡 思考题

❓ 为什么「打开」和「保存」要用 addAction 而不是 addButton
答案QAction 是 PyQt 的统一事件处理单元(不是按钮!),它能绑定到菜单/按钮/工具栏。

🧩 第四步:实现「打开文件」功能(关键!)

❌ 常见错误:忘记 with open → 文件没关闭 → 内存泄漏!

✅ 正确逻辑:用户点击 → 弹出文件选择框 → 读取文件 → 显示到编辑器

📝 代码详解(带思考注释):

defopen_file(self):# ✨ 为什么用 QFileDialog.getOpenFileName?因为这是PyQt的标准文件选择器 path, _ = QFileDialog.getOpenFileName( self,# 父窗口(确保弹窗在记事本内部)"打开文件",# 窗口标题"",# 默认打开路径(留空表示当前目录)"Text Files (*.txt);;All Files (*)"# 文件过滤器(显示.txt和所有文件))# ✨ 为什么需要检查 path?因为用户可能点了「取消」!if path:# ✨ 为什么用 'r' 和 utf-8?因为读取文本文件,且支持中文withopen(path,'r', encoding='utf-8')as f: self.editor.setText(f.read())# 将文件内容放入编辑器# ✨ 为什么更新状态栏?让用户知道发生了什么 self.statusBar().showMessage(f"已打开: {path}")

💡 思考题

❓ 如果用户打开一个 .jpg 文件会怎样?
答案:程序会崩溃!因为 f.read() 读的是二进制,不是文本。这就是为什么需要文件过滤器"Text Files (*.txt)")。

🧩 第五步:实现「字数统计」(小白最爱的功能!)

❌ 常见错误:用 self.editor.text() → 会包含HTML标签!

✅ 正确逻辑:实时监听文字变化 → 计算纯文本字数

📝 代码详解(关键在 textChanged 信号):

# 1️⃣ 初始化状态栏(在 initUI 里) self.statusBar().showMessage("准备就绪")# 初始状态# 2️⃣ 监听文字变化(核心!) self.editor.textChanged.connect(self.update_status)# 当文字变化时,自动调用 update_status# 3️⃣ 实现统计函数defupdate_status(self): text = self.editor.toPlainText()# ✨ 为什么用 toPlainText?因为这是纯文本! char_count =len(text)# 字符数(含空格) line_count =len(text.split('\n'))# 行数(按换行符分割)# 更新状态栏(为什么用 f-string?因为可读性高!) self.statusBar().showMessage(f"字数: {char_count} | 行数: {line_count}")

💡 思考题

❓ 为什么 text.split('\n') 能算行数?如果用户用的是 \r\n(Windows换行符)会怎样?
答案split('\n') 会把 \r\n 当成两个字符,导致行数多1。正确做法:用 text.splitlines()(PyQt内置方法,自动处理换行符)。

🧩 第六步:为什么需要「类结构」?(小白的终极困惑)

❌ 常见错误:把所有代码写在全局(导致变量混乱!)

✅ 正确逻辑:用类封装所有功能 → 代码清晰 + 方便绑定槽函数

📝 为什么这样写?

classSimplePad(QMainWindow):# 继承自QMainWindow(让记事本拥有窗口能力)def__init__(self):super().__init__()# 初始化父类(必须!) self.initUI()# 自己写的初始化方法definitUI(self):# 这里放所有界面初始化代码(窗口、编辑器、菜单等)# ✨ 为什么不用全局变量?因为:1. 代码可读性高 2. 便于多人协作 3. 避免变量覆盖

💡 思考题

❓ 如果我删掉 super().__init__() 会怎样?
答案:窗口会报错!因为 QMainWindow 的初始化逻辑没执行(PyQt要求必须调用父类构造函数)。

✅ 最终代码(完整版,带详细注释)

import sys from PyQt6.QtWidgets import QApplication, QMainWindow, QTextEdit, QFileDialog, QFontDialog, QMenuBar, QStatusBar classSimplePad(QMainWindow):def__init__(self):super().__init__()# 1️⃣ 必须初始化父类 self.initUI()# 2️⃣ 初始化界面definitUI(self):# 🔧 1. 设置窗口基础属性 self.setWindowTitle("SimplePad - 我的第一个记事本") self.resize(800,600)# 更大的窗口(方便看字数)# 📝 2. 创建文本编辑器(核心!) self.editor = QTextEdit() self.setCentralWidget(self.editor)# 设置为窗口中央内容# 📋 3. 创建菜单栏(分步骤构建) menubar = self.menuBar()# 获取菜单栏# 文件菜单 file_menu = menubar.addMenu("文件") file_menu.addAction("新建").triggered.connect(self.editor.clear)# 新建 → 清空 file_menu.addAction("打开").triggered.connect(self.open_file)# 打开 → 绑定函数 save_action = file_menu.addAction("保存") save_action.setShortcut("Ctrl+S")# 快捷键 save_action.triggered.connect(self.save_file)# 保存 → 绑定函数# 格式菜单 format_menu = menubar.addMenu("格式") format_menu.addAction("字体设置").triggered.connect(self.change_font)# 📊 4. 状态栏(字数统计) self.statusBar().showMessage("准备就绪") self.editor.textChanged.connect(self.update_status)# 关键!监听文字变化# ⚙️ 5. 打开文件(带错误处理)defopen_file(self): path, _ = QFileDialog.getOpenFileName( self,"打开文件","","Text Files (*.txt);;All Files (*)")if path:# ✅ 检查用户是否选择了文件withopen(path,'r', encoding='utf-8')as f: self.editor.setText(f.read()) self.statusBar().showMessage(f"已打开: {path}")# 📦 6. 保存文件(带用户友好提示)defsave_file(self): path, _ = QFileDialog.getSaveFileName( self,"保存文件","","Text Files (*.txt)")if path: content = self.editor.toPlainText()# ✨ 纯文本!withopen(path,'w', encoding='utf-8')as f: f.write(content) self.statusBar().showMessage(f"已保存: {path}")# 🎨 7. 字体设置(用标准对话框)defchange_font(self): font, ok = QFontDialog.getFont()if ok: self.editor.setFont(font)# 📊 8. 字数统计(实时更新!)defupdate_status(self): text = self.editor.toPlainText() char_count =len(text) line_count =len(text.splitlines())# ✨ 正确处理换行符! self.statusBar().showMessage(f"字数: {char_count} | 行数: {line_count}")# 🚀 启动程序if __name__ =="__main__": app = QApplication(sys.argv) window = SimplePad() window.show() sys.exit(app.exec())

Read more

ABB 机器人虚拟示教器基础操作教程

ABB 机器人虚拟示教器基础操作教程

一、基础操作界面与模式 1. 操作模式切换 * 手动模式:用于编程、调试和手动操作 自动模式:用于程序自动运行(需满足安全条件) 2. 动作模式选择(手动模式下) * 单轴模式:单独控制每个关节轴(1-6轴) * 优点:最直观,与坐标系无关 * 用途:调整机器人姿态,避免奇异点 * 线性模式:TCP沿直线运动 * 重定位模式:TCP位置不变,只改变工具姿态 点击示教器左上角 进入菜单栏 3. 坐标系选择(线性/重定位模式下) 四个可选坐标系: * 大地坐标系:机器人安装的基础坐标系 * 基座坐标系:机器人底座中心为原点(多数基本选择) * 工件坐标系:用户自定义的工作平面 * 工具坐标系:以工具末端为原点 二、三大核心数据设置 1. 工具数据(tooldata) 定义:描述工具(

By Ne0inhk

2026年RAG技术路线图:基于DeepSeek与Neo4j知识图谱构建企业智能体系

RAG的演进:为何图检索增强生成(GraphRAG)将主导2026年 检索增强生成(RAG)自问世以来经历了深刻变革,2026年标志着其向图检索增强生成(GraphRAG)范式的关键性转变。这一演进源于传统平面向量型RAG在满足企业级复杂推理和可靠决策支持需求方面日益凸显的局限性。 这一转型的核心驱动力是从平面向量相似性向复杂关系推理的跨越。传统RAG依赖向量嵌入来衡量查询与文档片段的语义相似性,但这种方法无法捕捉企业决策至关重要的实体、概念与事件间的复杂关联。相比之下,GraphRAG将信息构建为包含节点(实体)和边(关系)的知识图谱,使模型能够遍历并推理这些关联——解锁了平面向量RAG无法实现的多跳推理和上下文关系理解能力。 GraphRAG还解决了传统RAG的两大长期痛点:上下文窗口限制和“中间信息丢失”问题。随着企业查询日益复杂,需要更大的上下文窗口来整合相关信息,但即便是最先进的大语言模型(LLM)也存在有限的上下文容量。GraphRAG通过将结构化知识存储在外部图数据库中解决了这一问题,允许模型按需检索最相关的节点和关系,而非将大量文本塞入上下文窗口。此外,“中间信息

By Ne0inhk

一键部署Z-Image-Turbo:云端AI绘画不求人

一键部署Z-Image-Turbo:云端AI绘画不求人 你是不是也遇到过这样的场景:脑子里有个绝妙的画面,想把它画出来,但要么不会画画,要么打开专业绘图软件折腾半天,最后出来的效果还不如想象力的十分之一? 或者,作为内容创作者、电商运营,每天需要大量配图、海报,找图库要花钱,自己设计又太费时间,效率低得让人抓狂。 今天,我要给你介绍一个“神器”——Z-Image-Turbo 极速云端创作室。它不是一个复杂的软件,而是一个打包好的云端AI绘画应用。你不需要懂代码,不需要配置环境,甚至不需要高性能电脑,只需要点几下鼠标,就能拥有一个属于你自己的、能秒级生成高清大图的AI画室。 这听起来是不是有点不可思议?别急,跟着我,10分钟你就能亲手把它搭建起来,并画出第一张作品。 1. 为什么你需要这个“云端画室”? 在深入动手之前,我们先搞清楚,这个工具到底能帮你解决什么问题。 1.1 传统AI绘画的三大痛点 如果你之前尝试过一些AI绘画工具,可能会对这几个问题深有体会: 1. 部署复杂:想用开源的Stable Diffusion?光是安装Python、

By Ne0inhk
Flash Table实测:JAI赋能低代码开发,重塑企业级应用构建范式

Flash Table实测:JAI赋能低代码开发,重塑企业级应用构建范式

目录 * 🔍 引言 * 1.1 什么是Flash Table * 1.2 低代码平台的进化与FlashTable的革新 * ✨FlashTable背景:为什么需要新一代低代码平台? * 2.1 传统开发的痛点 * 2.2 低代码平台的局限 * 2.3 FlashTable的差异化定位 * 💻 FlashTable安装:Docker部署&Jar包部署 * 3.1 基础环境要求 * 3.2 Docker部署(推荐方案) * 3.3 Jar包部署(无Docker环境) * 3.4 常见问题 * 📚FlashTable功能深度评测:从案例看真实能力 * 4.1 数据孤岛?FlashTable 自动化匹配字段 * 4.2 FlashTable复杂表单的开发挑战 * 4.3

By Ne0inhk