当前位置: 首页 > article >正文

Python实现的在线词典学习工具

Python实现的在线词典学习工具

源码最初来自网络,根据实际情况进行了修改。

主要功能:

单词查询

    通过Bing词典在线获取单词释义(正则提取网页meta描述),支持回车键快速查询

    内置网络请求重试和异常处理机制

    在线网页

生词本管理

    SQLite数据库(wordlist.db)存储单词(含释义、添加时间、难度等级)

支持:

        批量删除单词

        多选导出

        按时间倒序展示

        数据刷新

文档导出

    全量/选择性导出为TXT文档

    自动生成带格式的文档:时间戳标注

运行界面

此程序用到了Python中的一些库和模块,下面是简要解释:

    requests 是一个用于发送HTTP请求的第三方库。它让你可以非常轻松地与Web服务交互。这个库不是Python标准库的一部分,因此需要安装。

    re 是Python标准库中的正则表达式模块,用于字符串匹配和查找。不需要额外安装。

    ttkbootstrap 是一个为Tkinter提供Bootstrap样式的第三方库,使得创建具有现代外观的GUI应用程序变得更加容易。这不是Python标准库的一部分,因此需要安装。

    tkinter是Python的标准GUI库,所以不需要额外安装。

    sqlite3 是Python标准库中的一个模块,允许你直接使用SQLite数据库。不需要额外安装。

    os 是Python标准库中的一个模块,提供了与操作系统交互的功能。不需要额外安装。

    datetime 是Python标准库中的一个模块,用于处理日期和时间。这里仅导入了datetime类。不需要额外安装。

    webbrowser 是Python标准库中的一个模块,用于提供对系统浏览器的控制。不需要额外安装。

总结起来,你需要安装的是requests和ttkbootstrap这两个库。你可以通过以下命令来安装它们(假设你还没有用pip安装)。

源码如下:

import requests
import re
import ttkbootstrap as ttk
from ttkbootstrap.constants import *
from ttkbootstrap.dialogs import Messagebox, Querybox
from tkinter import filedialog
import sqlite3
import os
from datetime import datetime
import webbrowserclass DictionaryApp:def __init__(self):# 初始化配置self.url = "https://cn.bing.com/dict/search"self.session = requests.Session()self.session.headers.update({'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36'})# 数据库连接self.db_file = 'wordlist.db'self.conn = sqlite3.connect(self.db_file)self.cursor = self.conn.cursor()self._init_db()# 临时存储列表self.temp_words = []# 创建主界面self.root = ttk.Window(title="在线词典工具", themename="litera")self.root.geometry("800x600")self._setup_ui()def _init_db(self):"""初始化数据库表结构"""try:self.cursor.execute("""CREATE TABLE IF NOT EXISTS words (id INTEGER PRIMARY KEY AUTOINCREMENT,word TEXT UNIQUE,meaning TEXT,add_time TEXT,difficulty INTEGER DEFAULT 1)""")self.conn.commit()except sqlite3.Error as e:Messagebox.show_error(f"数据库初始化失败: {str(e)}")def _setup_ui(self):"""设置用户界面"""# 顶部标题ttk.Label(self.root, text="词典工具", font=("微软雅黑", 16, "bold"),bootstyle="primary").pack(pady=10)# 搜索区域search_frame = ttk.Frame(self.root)search_frame.pack(fill=X, padx=10, pady=5)self.search_entry = ttk.Entry(search_frame, width=40,font=("微软雅黑", 12))self.search_entry.pack(side=LEFT, padx=5)self.search_entry.bind("<Return>", lambda e: self.search_word())ttk.Button(search_frame, text="在线查询", command=self.search_word,bootstyle="primary").pack(side=LEFT, padx=5)ttk.Button(search_frame, text="在线网页", command=self.search_online,bootstyle="info").pack(side=LEFT, padx=5)# 结果显示区域result_frame = ttk.Frame(self.root)result_frame.pack(fill=BOTH, expand=True, padx=10, pady=5)self.result_text = ttk.ScrolledText(result_frame, font=("微软雅黑", 11),wrap=WORD,height=15)self.result_text.pack(fill=BOTH, expand=True)self.result_text.config(state=DISABLED)# 操作按钮区域btn_frame = ttk.Frame(self.root)btn_frame.pack(fill=X, padx=10, pady=10)ttk.Button(btn_frame, text="添加到生词本", command=self.add_to_vocabulary,bootstyle="success").pack(side=LEFT, padx=5)ttk.Button(btn_frame, text="清空结果", command=self.clear_results,bootstyle="warning").pack(side=LEFT, padx=5)ttk.Button(btn_frame, text="管理生词本", command=self.manage_vocabulary,bootstyle="secondary").pack(side=LEFT, padx=5)ttk.Button(btn_frame, text="生词本导出为TXT", command=self.export_to_txt,bootstyle="primary-outline").pack(side=RIGHT, padx=5)# 状态栏self.status_var = ttk.StringVar()self.status_var.set("就绪")ttk.Label(self.root, textvariable=self.status_var,relief=SUNKEN,anchor=W).pack(fill=X, side=BOTTOM, ipady=2)# 窗口关闭事件self.root.protocol("WM_DELETE_WINDOW", self.on_close)def search_word(self):"""查询单词:Bing词典API在线获取单词释义(正则提取网页meta描述)"""word = self.search_entry.get().strip()if not word:Messagebox.show_warning("请输入要查询的单词", parent=self.root)returnself.status_var.set(f"正在查询: {word}...")self.root.update()try:result = self._search_word(word)self._display_result(word, result)self.status_var.set(f"查询完成: {word}")except requests.ConnectionError:Messagebox.show_error("网络连接失败,请检查您的网络连接", parent=self.root)self.status_var.set("查询失败: 网络连接错误")except requests.Timeout:Messagebox.show_error("查询超时,请稍后再试", parent=self.root)self.status_var.set("查询失败: 连接超时")except requests.RequestException as e:Messagebox.show_error(f"请求错误: {str(e)}", parent=self.root)self.status_var.set("查询失败: 请求错误")except Exception as e:Messagebox.show_error(f"查询失败: {str(e)}", parent=self.root)self.status_var.set("查询失败: 未知错误")def _search_word(self, word):"""实际执行查询"""params = {"q": word}try:resp = self.session.get(self.url, params=params, timeout=10)resp.raise_for_status()# 使用正则提取释义pattern = re.compile(r'<meta name="description" content=".*的释义,(?P<meaning>.*?)" />')match = pattern.search(resp.text)if match:meaning = match.group("meaning")return meaningreturn Noneexcept requests.exceptions.Timeout:raise requests.Timeout("查询超时,服务器响应时间过长")except requests.exceptions.ConnectionError:raise requests.ConnectionError("网络连接失败,请检查网络设置")except requests.exceptions.HTTPError as e:if e.response.status_code == 404:return Noneraise requests.RequestException(f"HTTP错误: {e.response.status_code}")except requests.exceptions.RequestException as e:raise requests.RequestException(f"请求错误: {str(e)}")def _display_result(self, word, meaning):"""显示查询结果"""self.result_text.config(state=NORMAL)self.result_text.delete(1.0, END)if meaning:# 添加单词self.result_text.insert(END, f"单词: ", "bold")self.result_text.insert(END, f"{word}\n", "word")# 添加释义self.result_text.insert(END, "\n释义:\n", "bold")meanings = meaning.split(',')for i, m in enumerate(meanings, 1):self.result_text.insert(END, f"{i}. {m}\n")# 临时存储self.temp_words = [(word, meaning)]else:self.result_text.insert(END, f"未找到单词 '{word}' 的释义\n", "error")self.result_text.config(state=DISABLED)def add_to_vocabulary(self):"""添加到生词本"""if not self.temp_words:Messagebox.show_warning("没有可添加的单词", parent=self.root)returnsuccess = 0for word, meaning in self.temp_words:try:self.cursor.execute("INSERT OR IGNORE INTO words (word, meaning, add_time) VALUES (?, ?, ?)",(word, meaning, datetime.now().strftime("%Y-%m-%d %H:%M:%S")))success += 1except sqlite3.Error as e:self.status_var.set(f"添加单词 '{word}' 失败: {str(e)}")continueself.conn.commit()Messagebox.show_info(f"成功添加 {success}/{len(self.temp_words)} 个单词到生词本", parent=self.root)self.temp_words = []def clear_results(self):"""清空结果"""self.result_text.config(state=NORMAL)self.result_text.delete(1.0, END)self.result_text.config(state=DISABLED)self.temp_words = []self.status_var.set("已清空结果")def manage_vocabulary(self):"""管理生词本"""manage_window = ttk.Toplevel(title="生词本管理")manage_window.geometry("900x600")# 创建树形表格columns = ("word", "meaning", "add_time")tree = ttk.Treeview(manage_window,columns=columns,show="headings",selectmode="extended",bootstyle="primary")# 设置列tree.heading("word", text="单词", anchor=W)tree.heading("meaning", text="释义", anchor=W)tree.heading("add_time", text="添加时间", anchor=W)tree.column("word", width=150, minwidth=100)tree.column("meaning", width=500, minwidth=300)tree.column("add_time", width=150, minwidth=100)# 添加滚动条scrollbar = ttk.Scrollbar(manage_window, orient=VERTICAL, command=tree.yview)tree.configure(yscrollcommand=scrollbar.set)scrollbar.pack(side=RIGHT, fill=Y)tree.pack(fill=BOTH, expand=True, padx=5, pady=5)# 加载数据self._load_vocabulary_data(tree)# 操作按钮区域btn_frame = ttk.Frame(manage_window)btn_frame.pack(fill=X, padx=5, pady=5)ttk.Button(btn_frame,text="删除选中",command=lambda: self._delete_selected_words(tree),bootstyle="danger").pack(side=LEFT, padx=5)ttk.Button(btn_frame,text="导出选中",command=lambda: self._export_selected_words(tree),bootstyle="success").pack(side=LEFT, padx=5)ttk.Button(btn_frame,text="刷新列表",command=lambda: self._load_vocabulary_data(tree),bootstyle="info").pack(side=RIGHT, padx=5)def _load_vocabulary_data(self, tree):"""加载生词本数据到表格"""try:# 清空现有数据for item in tree.get_children():tree.delete(item)# 获取数据并显示rows = self.cursor.execute("""SELECT word, meaning, add_time FROM words ORDER BY add_time DESC""").fetchall()for row in rows:tree.insert("", END, values=row)except sqlite3.Error as e:Messagebox.show_error(f"加载数据失败: {str(e)}", parent=tree.winfo_toplevel())def _delete_selected_words(self, tree):"""删除选中的单词"""selected_items = tree.selection()if not selected_items:Messagebox.show_warning("请先选择要删除的单词", parent=tree.winfo_toplevel())returnif not Messagebox.yesno("确认删除",f"确定要删除这 {len(selected_items)} 个单词吗?",parent=tree.winfo_toplevel()):returndeleted = 0try:for item in selected_items:values = tree.item(item)['values']if values:  # 确保有值word = values[0]  # 获取单词self.cursor.execute("DELETE FROM words WHERE word=?", (word,))deleted += 1self.conn.commit()Messagebox.show_info(f"成功删除 {deleted} 个单词", parent=tree.winfo_toplevel())# 刷新显示self._load_vocabulary_data(tree)except sqlite3.Error as e:Messagebox.show_error(f"删除失败: {str(e)}", parent=tree.winfo_toplevel())def _export_selected_words(self, tree):"""导出选中的单词"""selected_items = tree.selection()if not selected_items:Messagebox.show_warning("请先选择要导出的单词", parent=tree.winfo_toplevel())returnwords = []for item in selected_items:values = tree.item(item)['values']if values:  # 确保有值words.append({"word": values[0],"meaning": values[1],"time": values[2]})if not words:Messagebox.show_warning("没有可导出的单词", parent=tree.winfo_toplevel())return# 调用导出功能default_filename = f"选中单词_{datetime.now().strftime('%Y%m%d_%H%M%S')}.txt"# 让用户选择保存位置from tkinter import filedialogfilepath = filedialog.asksaveasfilename(initialfile=default_filename,defaultextension=".txt",filetypes=[("文本文档", "*.txt")],parent=tree.winfo_toplevel())if not filepath:returntry:with open(filepath, 'w', encoding='utf-8') as f:# 写入标题f.write("选中的单词\n")f.write("="*50 + "\n\n")# 写入统计信息f.write(f"共 {len(words)} 个单词 | 导出时间: {datetime.now().strftime('%Y-%m-%d %H:%M:%S')}\n\n")# 写入单词内容for item in words:f.write(f"■ {item['word']}  ({item['time']})\n")f.write(f"  {item['meaning']}\n")f.write("-"*50 + "\n")Messagebox.show_info(f"成功导出 {len(words)} 个单词到:\n{filepath}", parent=tree.winfo_toplevel())# 询问是否打开文件if Messagebox.yesno("确认打开","导出成功,是否现在打开文件?",parent=tree.winfo_toplevel()):webbrowser.open(filepath)except IOError as e:Messagebox.show_error(f"写入文件失败: {str(e)}", parent=tree.winfo_toplevel())except Exception as e:Messagebox.show_error(f"导出失败: {str(e)}", parent=tree.winfo_toplevel())def export_to_txt(self):"""导出全部单词到TXT"""words = []try:rows = self.cursor.execute("""SELECT word, meaning, add_time FROM words ORDER BY word COLLATE NOCASE""").fetchall()for row in rows:words.append({"word": row[0],"meaning": row[1],"time": row[2]})except sqlite3.Error as e:Messagebox.show_error(f"加载数据失败: {str(e)}", parent=self.root)returnif not words:Messagebox.show_warning("生词本为空,没有可导出的单词", parent=self.root)returnself._export_words_to_file(words)def _export_words_to_file(self, words):"""实际执行导出到TXT文件"""default_filename = f"单词表_{datetime.now().strftime('%Y%m%d_%H%M%S')}.txt"# 让用户选择保存位置 - 修复Querybox错误from tkinter import filedialogfilepath = filedialog.asksaveasfilename(initialfile=default_filename,defaultextension=".txt",filetypes=[("文本文档", "*.txt")],parent=self.root)if not filepath:returntry:with open(filepath, 'w', encoding='utf-8') as f:# 写入标题f.write("我的生词本\n")f.write("="*50 + "\n\n")# 写入统计信息f.write(f"共 {len(words)} 个单词 | 生成时间: {datetime.now().strftime('%Y-%m-%d %H:%M:%S')}\n\n")# 写入单词内容for item in words:f.write(f"■ {item['word']}  ({item['time']})\n")f.write(f"  {item['meaning']}\n")f.write("-"*50 + "\n")Messagebox.show_info(f"成功导出 {len(words)} 个单词到:\n{filepath}", parent=self.root)# 询问是否打开文件if Messagebox.show_question("导出成功,是否现在打开文件?",parent=self.root) == "是":webbrowser.open(filepath)except IOError as e:Messagebox.show_error(f"写入文件失败: {str(e)}", parent=self.root)except Exception as e:Messagebox.show_error(f"导出失败: {str(e)}", parent=self.root)def search_online(self):"""在浏览器中在线搜索:直连Bing词典(原始页面查看)"""word = self.search_entry.get().strip()if not word:Messagebox.show_warning("请输入要查询的单词", parent=self.root)returnurl = f"https://cn.bing.com/dict/search?q={word}"try:webbrowser.open(url)except Exception as e:Messagebox.show_error(f"打开浏览器失败: {str(e)}", parent=self.root)def on_close(self):"""关闭窗口时的清理工作"""try:self.conn.commit()self.conn.close()self.session.close()self.root.destroy()except Exception as e:print(f"关闭时出错: {str(e)}")self.root.destroy()if __name__ == '__main__':app = DictionaryApp()app.root.mainloop()

相关文章:

Python实现的在线词典学习工具

Python实现的在线词典学习工具 源码最初来自网络&#xff0c;根据实际情况进行了修改。 主要功能&#xff1a; 单词查询 通过Bing词典在线获取单词释义&#xff08;正则提取网页meta描述&#xff09;&#xff0c;支持回车键快速查询 内置网络请求重试和异常处理机制 在线网页…...

ES常识9:如何实现同义词映射(搜索)

在 Elasticsearch&#xff08;ES&#xff09;中实现同义词映射&#xff08;如“美丽”和“漂亮”&#xff09;&#xff0c;核心是通过 同义词过滤器&#xff08;Synonym Token Filter&#xff09; 在分词阶段将同义词扩展或替换为统一词项&#xff0c;从而让搜索时输入任意一个…...

BGP综合实验(2)

一、实验需求 1、实验拓扑图 2、实验需求 使用 PreVal 策略&#xff0c;让 R4 经 R2 到达 192.168.10.0/24 。 使用 AS_Path 策略&#xff0c;让 R4 经 R3 到达 192.168.11.0/24 。 配置 MED 策略&#xff0c;让 R4 经 R3 到达 192.168.12.0/24 。 使用 Local Preference 策…...

java实现poi-ooxml导出Excel的功能

文章目录 1. 添加poi-ooxml依赖2. Excel导出工具类3.核心逻辑说明4.扩展建议5.HSSF、XSSF、SXSSF 的核心原则和场景建议&#xff0c;帮助你在不同需求下快速决策&#xff1a; 以下是一个基于 Apache POI 实现的简单、通用的Java导出Excel工具类&#xff0c;代码逻辑清晰且注释详…...

代码随想录算法训练营 Day51 图论Ⅱ岛屿问题Ⅰ

图论 题目 99. 岛屿数量 使用 DFS 实现方法 判断岛屿方法 1. 遍历图&#xff0c;若遍历到了陆地 grid[i][j] 1 并且陆地没有被访问&#xff0c;在这个陆地的基础上进行 DFS 方法&#xff0c;或者是 BFS 方法 2. 对陆地进行 DFS 的时候时刻注意以访问的元素添加访问标记 //…...

【占融数科-注册/登录安全分析报告】

前言 由于网站注册入口容易被黑客攻击&#xff0c;存在如下安全问题&#xff1a; 暴力破解密码&#xff0c;造成用户信息泄露短信盗刷的安全问题&#xff0c;影响业务及导致用户投诉带来经济损失&#xff0c;尤其是后付费客户&#xff0c;风险巨大&#xff0c;造成亏损无底洞…...

【CF】Day62——Codeforces Round 948 (Div. 2) CD (思维 + LCM + 枚举因数 | 思维 + 哈希)

C. Nikita and LCM 题目&#xff1a; 思路&#xff1a; 非常好的思维题&#xff0c;顺便复习了一下快速枚举因数和lcm的性质 我们先来看答案的上界&#xff0c;即全选&#xff0c;此时说明 lcm(a1,a2,a3,...) > a_max 其中 a_max 为 a 中最大的数&#xff0c;那么如果答案不…...

基于requests_html的python爬虫

前言&#xff1a;今天介绍一个相对性能更高的爬虫库requests_html&#xff0c;会不会感觉和requests有点联系&#xff1f;是的。为什么开始不直接介绍呢&#xff1f;因为我觉得requests是最基本入门的东西&#xff0c;并且在学习过程中也能学到很多东西。我的python老师在介绍这…...

循环神经网络:捕捉序列数据中的时间信息

目录 循环神经网络&#xff1a;捕捉序列数据中的时间信息 一、循环神经网络的基本概念 &#xff08;一&#xff09;RNN 的基本结构 &#xff08;二&#xff09;RNN 的工作原理 &#xff08;三&#xff09;RNN 的优势 &#xff08;四&#xff09;RNN 的局限性 二、循环神…...

第35周Zookkeeper+Dubbo 面试题精讲

面试题精讲 一、算法面试答题思路 理解思路的重要性:算法面试比基础面试更复杂,需先想清楚思路,与面试官沟通确认题目条件(如数据范围、是否包含负数/零等),这有助于理清解题思路并展示技术实力。变量命名清晰:算法中变量命名要明确含义和范围,避免使用模糊的变量名,…...

聊聊更新中断和更新事件那些事儿

最近在研究一些系统和设备的更新机制&#xff0c;发现更新中断和更新事件这两个概念很有意思&#xff0c;也容易让人混淆&#xff0c;今天就来和大家好好探讨一下。 一、更新事件 &#xff08;一&#xff09;定义与原理 更新事件&#xff0c;简单来说&#xff0c;是当出现某…...

STM32:按键模块 传感器模块 以及 相关C语言知识(详细讲解)

目录 按键 传感器模块 C语言知识 C语言数据类型 C语言宏定义 C语言typedef C语言结构体 C语言枚举 按键 常见的输入设备&#xff0c;按下导通&#xff0c;松手断开 按键抖动&#xff1a;由于按键内部使用的是机械式弹簧片来进行通断的&#xff0c;所以在按下和松手的瞬…...

C++23 std::mdspan:多维数组处理新利器

文章目录 引言C23简介std::mdspan的定义与特点定义特点 std::mdspan的优势零成本抽象的多维数据访问减少内存开销提高代码灵活性 std::mdspan的应用场景科学计算图形学 相关提案示例代码使用动态扩展使用静态和动态扩展 总结 引言 在C的发展历程中&#xff0c;每一个新版本都带…...

基于高德MCP2.0的智能旅游攻略系统设计与实现

前言&#xff1a;旅游规划的技术革命 在数字化旅游时代&#xff0c;MCP2.0&#xff08;Map-based Collaborative Planning&#xff09;系统代表着旅游攻略技术的最新演进。作为对1.0版本的全面升级&#xff0c;MCP2.0通过深度整合高德地图API和智能算法&#xff0c;实现了从静…...

【时时三省】(C语言基础)用函数实现模块化程序设计

山不在高&#xff0c;有仙则名。水不在深&#xff0c;有龙则灵。 ----CSDN 时时三省 为什么要用函数&#xff1f; 已经能够编写一些简单的C程序&#xff0c;但是如果程序的功能比较多&#xff0c;规模比较大&#xff0c;把所有的程序代码都写在一个主函数(main函数)中&#x…...

Flink流处理:实时计算URL访问量TopN(基于时间窗口)

目录 代码分析 背景知识拓展 代码调优 1. 性能优化 1.1 使用 KeyedStream 和 ProcessWindowFunction 替代 windowAll 1.2 使用 ReduceFunction 优化聚合 2. 功能扩展 2.1 支持动态窗口大小 2.2 支持多维度统计 2.3 支持持久化存储 3. 代码可读性 3.1 提取公共逻辑 …...

初识函数------了解函数的定义、函数的参数、函数的返回值、说明文档的书写、函数的嵌套使用、变量的作用域(全局变量与局部变量)

文章目录 一、什么是函数&#xff1f;二、函数定义与调用2.1 基本语法2.2 示例演示 三、函数参数详解3.1 位置参数3.2 默认参数3.3 可变参数3.4 关键字参数 四、返回值与文档说明4.1 返回多个值4.2 编写文档字符串 五、函数嵌套与作用域5.1 嵌套函数示例5.2 变量作用域5.3 glob…...

java collection集合特点知识点详解

在 Java 中&#xff0c;Collection 是所有集合类的根接口&#xff0c;它定义了一组对象的基本操作。Java 集合框架提供了丰富的实现类&#xff08;如List、Set、Queue&#xff09;&#xff0c;具有以下核心特点&#xff1a; 一、统一的接口设计 1. 核心接口层次 Collection …...

ngx_http_realip_module 模块概述

一、使用场景 日志记录 记录真实客户端 IP 而非反向代理的 IP&#xff0c;有助于流量分析和安全审计。访问控制 基于真实 IP 实现防火墙规则&#xff08;allow/deny&#xff09;或限流&#xff0c;而非误将上游 IP 视为客户端。GeoIP、WAF、限速等功能 模块化的上游真实 IP 支…...

自定义CString类与MFC CString类接口对比

接口对比表格 功能分类 你的 CString 接口 MFC CString 接口&#xff08;ANSI&#xff09; 一致性 差异说明 构造函数 CString() CString(const char*) CString(char) CString(const CString&) CString() CString(LPCSTR) CString(TCHAR) CString(const CString&…...

华为OD机试真题——考勤信息(2025A卷:100分)Java/python/JavaScript/C/C++/GO最佳实现

2025 A卷 100分 题型 本专栏内全部题目均提供Java、python、JavaScript、C、C++、GO六种语言的最佳实现方式; 并且每种语言均涵盖详细的问题分析、解题思路、代码实现、代码详解、3个测试用例以及综合分析; 本文收录于专栏:《2025华为OD真题目录+全流程解析+备考攻略+经验分…...

Go语言测试用例的执行与分析

在软件开发过程中&#xff0c;测试用例是确保代码质量的关键环节。Go语言作为一种现代的编程语言&#xff0c;它内置了强大的测试框架&#xff0c;可以帮助开发者轻松编写和执行测试用例。本文将介绍如何在 Go 语言中编写、执行测试用例&#xff0c;并对测试结果进行分析。 ## …...

vue3 vite 路由

如路由是这种格式 http://localhost:7058/admin/product/brand路由配置如下 import { createRouter, createWebHistory } from vue-router import HomeView from ../views/HomeView.vue import NProgress from nprogress; import nprogress/nprogress.css; import {errorRour…...

MyBatis:动态SQL

文章目录 动态SQLif标签trim标签where标签set标签foreach标签include标签和sql标签 Mybatis动态SQL的官方文档&#xff1a; https://mybatis.net.cn/dynamic-sql.html 动态SQL 动态SQL是 MyBatis的强大特性之一,如果是使用JDBC根据不同条件拼接sql很麻烦&#xff0c;例如拼接…...

游戏引擎学习第280天:精简化的流式实体sim

回顾并为今天的内容做铺垫 今天的任务是让之前关于实体存储方式的改动真正运行起来。我们现在希望让实体系统变得更加真实和实用&#xff0c;能够支撑我们游戏实际所需的功能。这就要求我们对它进行更合理的实现和调试。 昨天我们基本让代码编译通过了&#xff0c;但实际上还…...

femap许可与多用户共享

随着电磁仿真技术的发展&#xff0c;Femap作为一款领先的工具&#xff0c;在多个领域中发挥着不可替代的作用。然而&#xff0c;对于许多团队和企业来说&#xff0c;如何高效、经济地管理和使用Femap许可证成为了一个亟待解决的问题。本文将探讨Femap许可与多用户共享的概念、优…...

王树森推荐系统公开课 排序03:预估分数融合

融合预估分数 p c l i c k ⋅ p l i k e p_{click} \cdot p_{like} pclick​⋅plike​ 有实际意义&#xff0c;等于在曝光中点赞的概率。 p c l i c k ⋅ p c o l l e c t p_{click} \cdot p_{collect} pclick​⋅pcollect​ 同理。 按多种排名做 ensemble sort。 某电商的融…...

网络I/O学习-poll(三)

一、为什么要用Poll 由于select参数太多&#xff0c;较于复杂&#xff0c;调用起来较为麻烦&#xff1b;poll对其进行了优化 二、poll机制 poll也是一个系统调用&#xff0c;每次调用都会将所有客户端的fd拷贝到内核空间&#xff0c;然后进行轮询&#xff0c;判断IO是否就绪…...

k8s(12) — 版本控制和滚动更新(金丝雀部署理念)

金丝雀部署简介&#xff1a; 1、基本概念 金丝雀部署是一种软件开发中的渐进式发布策略&#xff0c;其核心思想是通过将新版本应用逐步发布给一小部分用户&#xff08;即 “金丝雀” 用户&#xff09;&#xff0c;在真实环境中验证功能稳定性和性能表现&#xff0c;再逐步扩大发…...

【git config --global alias | Git分支操作效率提升实践指南】

git config --global alias | Git分支操作效率提升实践指南 背景与痛点分析 在现代软件开发团队中&#xff0c;Git分支管理是日常工作的重要组成部分。特别是在规范的开发流程中&#xff0c;我们经常会遇到类似 feature/user-management、bugfix/login-issue 或 per/cny/dev …...