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

浏览器书签智能分类

浏览器书签智能分类工具

最近发现浏览器的书签越来越乱了,主要是因为自己太懒,其次之前建的分类太多又乱,重新手动整理确实比较烦。因此有了这个小项目。借助智谱AI的力量对书签进行重新分类。

项目简介

本工具用于自动整理浏览器书签,通过AI智能分类技术,将杂乱的书签按照主题自动归类,并且重新生成结构化的书签文件。

功能特性

  • 自动提取书签信息
  • 智能分类书签内容
  • 分类智能生成
  • 生成HTML格式书签文件,可直接导入浏览器
  • 自动清理临时文件

使用说明

准备工作

  1. 获取智谱AI API密钥
  2. 准备浏览器导出的书签HTML文件

快速开始

  1. 下载脚本
  2. 修改CONFIG配置中的INPUT_FILEOUTPUT_FILE
  3. 修改CONFIG配置中的API_KEY
  4. 运行脚本:
    python 浏览器书签文件重新分类.py
    
  5. 查看生成的分类结果文件bookmarks.html

配置文件说明

在脚本开头的CONFIG字典中可配置以下参数:

  • API_KEY: 智谱AI API密钥(必填)
  • INPUT_FILE: 输入的书签HTML文件路径
  • EXTRACTED_FILE: 提取的临时文件路径
  • CLASSIFIED_FILE: 分类结果Markdown文件路径
  • OUTPUT_FILE: 最终输出的HTML书签文件路径
  • DEFAULT_CATEGORIES: 默认分类列表

代码结构

# 主要功能模块
1. 配置参数 (CONFIG)
2. AI客户端初始化 (zhipu_client)
3. 书签提取 (extract_bookmark_info)
4. 书签分类 (classify_bookmark)
5. 分类创建 (create_new_category)
6. 格式转换 (md_to_netscape)
7. 文件清理 (cleanup_temp_files)

脚本代码详细说明

浏览器书签文件重新分类脚本详细说明

1. 配置参数
CONFIG = {'API_KEY': "9e2458a8acf46274d1c1b9418eec500c.oBojpibVHt3IyXnz",  # 智谱API密钥,必填'INPUT_FILE': 'bookmarks_2025_1_3.html',  # 输入文件,必填'EXTRACTED_FILE': 'extracted_bookmarks.txt',  # 提取的临时文件'CLASSIFIED_FILE': 'classified_bookmarks.md',  # 分类结果文件'OUTPUT_FILE': 'bookmarks.html',  # 最终输出文件'DEFAULT_CATEGORIES': [  # 默认分类'编程语言','人工智能', '数据科学',]
}
  • API_KEY: 用于调用智谱AI API的密钥。
  • INPUT_FILE: 输入的HTML格式浏览器书签文件路径。
  • EXTRACTED_FILE: 提取的书签信息保存为文本文件的路径。
  • CLASSIFIED_FILE: 分类后的书签信息保存为Markdown文件的路径。
  • OUTPUT_FILE: 最终生成的HTML格式书签文件路径。
  • DEFAULT_CATEGORIES: 预定义的默认分类列表。
2. 初始化客户端
zhipu_client = ZhipuAI(api_key=CONFIG['API_KEY'])
  • 使用提供的API密钥初始化智谱AI客户端,用于后续与AI模型交互。
3. 获取AI响应
def get_llm_response(sysPrompt, questionPrompt):response = zhipu_client.chat.completions.create(model="GLM-4-Plus",  # 填写需要调用的模型编码messages=[{"role": "user", "content": sysPrompt},{"role": "assistant", "content": "你好,请告诉我你需要分类的书签?"},{"role": "user", "content": questionPrompt},],)return response.choices[0].message.content
  • 定义一个函数get_llm_response,用于向AI模型发送系统提示和用户问题,并返回模型的响应内容。
4. 读取并解析HTML文件
with open(CONFIG['INPUT_FILE'], 'r', encoding='utf-8') as file:html_content = file.read()soup = BeautifulSoup(html_content, 'html.parser')
bookmarks = soup.find_all('a')bookmark_info = []
for bookmark in bookmarks:href = bookmark.get('href')add_date = bookmark.get('add_date')icon = bookmark.get('icon')text = bookmark.text.strip().replace('\n', '').replace('\t', '').replace('\r', '').replace(' ', '')bookmark_info.append({'URL': href,'Text': text})with open(CONFIG['EXTRACTED_FILE'], 'w', encoding='utf-8') as f:for info in bookmark_info:f.write(f"Name: {info['Text']}, URL: {info['URL']}\n")
  • 读取输入的HTML书签文件内容。
  • 使用BeautifulSoup解析HTML,提取所有的<a>标签作为书签。
  • 将每个书签的URL和名称保存到bookmark_info列表中。
  • 将提取的书签信息保存到临时文件EXTRACTED_FILE中。
5. 分类书签
def extract_bookmark_info(line):name_match = re.search(r'Name: ([^,]+)', line)url_match = re.search(r'URL: (https?://[^\s]+)', line)if not name_match or not url_match:return None, Nonereturn name_match.group(1), url_match.group(1)def classify_bookmark(bookmark_name, bookmark_url, categories):system_prompt = ("你是一个智能助手,任务是根据提供的书签名称和URL从给定的分类列表中选择最合适的分类返回给用户。仅返回分类名称。\n""请根据书签的内容和性质选择最适合的分类。如果没有合适的分类,请回答'无法分类'。\n""给定分类: {categories_str}\n""请选择最合适的分类。\n""示例:""user: 书签名称:Python官方文档\n""书签URL:https://docs.python.org/3/\n""assistant: 编程语言\n").format(categories_str=", ".join(categories))user_prompt = ("书签名称: {bookmark_name}\n""书签URL: {bookmark_url}\n").format(bookmark_name=bookmark_name, bookmark_url=bookmark_url)try:response = get_llm_response(system_prompt, user_prompt)except Exception as e:response = "其他"if response == "无法分类":return Nonereturn responsedef create_new_category(name, url):system_prompt = ("你是一个智能助手,任务是根据提供的书签名称和URL给定一个合适的书签分类。仅返回分类名称。\n""请根据书签的内容和性质给定分类。\n""示例:""user: 书签名称:Python官方文档\n""书签URL:https://docs.python.org/3/\n""assistant: 编程语言\n")user_prompt = ("书签名称: {name}\n""书签URL: {url}\n").format(name=name, url=url)response = get_llm_response(system_prompt, user_prompt)return response
  • extract_bookmark_info: 从临时文件中每行提取书签名称和URL。
  • classify_bookmark: 根据书签名称和URL,使用AI模型从预定义分类中选择最合适的分类。如果无法分类,则返回None
  • create_new_category: 如果书签无法归入现有分类,则创建新分类。
6. 处理书签分类
categories = CONFIG['DEFAULT_CATEGORIES']with open(CONFIG['EXTRACTED_FILE'], 'r', encoding='utf-8') as f:bookmarks = f.readlines()classified = defaultdict(list)
for line in bookmarks:if not line.strip():continuename, url = extract_bookmark_info(line)if not name or not url:continuecategory = classify_bookmark(name, url, categories)if not category:category = create_new_category(name, url)categories.append(category)print(f'分类书签: {name} -> {category}')classified[category].append(line)with open(CONFIG['CLASSIFIED_FILE'], 'w', encoding='utf-8') as f:f.write('# 书签\n\n')for category, items in classified.items():f.write(f'## {category}\n')for item in items:name, url = extract_bookmark_info(item)if name and url:f.write(f'- [{name}]({url})\n')f.write('\n')
  • 从临时文件中读取所有书签信息。
  • 对每个书签进行分类,如果无法归入现有分类则创建新分类。
  • 将分类结果保存到Markdown文件CLASSIFIED_FILE中。
7. 将分类结果转换为HTML书签文件
def md_to_netscape(md_content):html = '''<!DOCTYPE NETSCAPE-Bookmark-file-1><META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=UTF-8"><TITLE>Bookmarks</TITLE><H1>Bookmarks</H1><DL><p>'''lines = md_content.split('\n')stack = []current_level = 0for line in lines:if line.startswith('#'):level = line.count('#')title = line.lstrip('#').strip()while stack and stack[-1] >= level:html += '</DL><p>\n'stack.pop()html += f'    <DT><H3 ADD_DATE="{int(datetime.now().timestamp())}" LAST_MODIFIED="{int(datetime.now().timestamp())}">{title}</H3>\n'html += '    <DL><p>\n'stack.append(level)current_level = levelelif line.startswith('-'):match = re.match(r'-\s*\[(.*?)\]\((.*?)\)', line)if match:name, url = match.groups()html += f'        <DT><A HREF="{url}" ADD_DATE="{int(datetime.now().timestamp())}">{name}</A>\n'while stack:html += '</DL><p>\n'stack.pop()return htmlwith open(CONFIG['CLASSIFIED_FILE'], 'r', encoding='utf-8') as f:md_content = f.read()html_content = md_to_netscape(md_content)with open(CONFIG['OUTPUT_FILE'], 'w', encoding='utf-8') as f:f.write(html_content)
  • 定义md_to_netscape函数,将Markdown格式的分类结果转换为Netscape Bookmark HTML格式。
  • 读取分类结果文件CLASSIFIED_FILE,将其转换为HTML格式并保存到OUTPUT_FILE
8. 清理临时文件
def cleanup_temp_files():temp_files = [CONFIG['EXTRACTED_FILE'],CONFIG['CLASSIFIED_FILE']]for file in temp_files:if os.path.exists(file):os.remove(file)print(f"已删除临时文件: {file}")if __name__ == '__main__':try:# 主逻辑代码...cleanup_temp_files()print("脚本执行完成,临时文件已清理")except Exception as e:print(f"脚本执行出错: {str(e)}")
  • 定义cleanup_temp_files函数,清理脚本运行过程中产生的临时文件。
  • 在主程序执行完成后调用此函数,确保临时文件被删除。

总结

该脚本通过以下步骤实现了对浏览器书签文件的重新分类:

  1. 读取和解析:从HTML文件中提取书签信息。
  2. 分类:使用AI模型对书签进行分类,必要时创建新分类。
  3. 保存结果:将分类结果保存为Markdown文件。
  4. 转换格式:将Markdown格式的分类结果转换为HTML格式。
  5. 清理:删除临时文件以保持工作环境整洁。

这个过程不仅简化了书签管理,还利用AI技术提高了分类的准确性和效率。

注意事项

  1. 确保API密钥有效
  2. 输入文件格式需为标准Netscape书签格式
  3. 分类结果可能受AI模型影响,建议人工复核
  4. 脚本运行后会清理临时文件,请及时保存结果

完整代码

# 浏览器书签文件重新分类.pyfrom zhipuai import ZhipuAI
from bs4 import BeautifulSoup
import re
import os
from collections import defaultdict
from datetime import datetime# 配置参数
CONFIG = {'API_KEY': "my-secret-key",  # 智谱API密钥,必填'INPUT_FILE': 'bookmarks_2025_1_3.html',  # 输入文件,必填'EXTRACTED_FILE': 'extracted_bookmarks.txt',  # 提取的临时文件'CLASSIFIED_FILE': 'classified_bookmarks.md',  # 分类结果文件'OUTPUT_FILE': 'bookmarks.html',  # 最终输出文件'DEFAULT_CATEGORIES': [  # 默认分类'编程语言',#这个被用到给AI举例,不能删除'人工智能', '数据科学',]
}# 初始化客户端
zhipu_client = ZhipuAI(api_key=CONFIG['API_KEY'])def get_llm_response(sysPrompt, questionPrompt):response = zhipu_client.chat.completions.create(model="GLM-4-Plus",  # 填写需要调用的模型编码messages = [{"role": "user", "content": sysPrompt},{"role": "assistant", "content": "你好,请告诉我你需要分类的书签?"},{"role": "user", "content": questionPrompt},],)return response.choices[0].message.content# 读取HTML文件内容
with open(CONFIG['INPUT_FILE'], 'r', encoding='utf-8') as file:html_content = file.read()# 使用BeautifulSoup解析HTML
soup = BeautifulSoup(html_content, 'html.parser')# 查找所有的<A>标签
bookmarks = soup.find_all('a')# 提取书签信息
bookmark_info = []
for bookmark in bookmarks:href = bookmark.get('href')add_date = bookmark.get('add_date')icon = bookmark.get('icon')text = bookmark.text.strip().replace('\n', '').replace('\t', '').replace('\r', '').replace(' ', '')bookmark_info.append({'URL': href,'Text': text})# 打印提取的书签信息
for info in bookmark_info:print(info)# 保存提取的书签信息with open(CONFIG['EXTRACTED_FILE'], 'w', encoding='utf-8') as f:for info in bookmark_info:f.write(f"Name: {info['Text']}, URL: {info['URL']}\n")def extract_bookmark_info(line):"""从书签行中提取名称和URL"""name_match = re.search(r'Name: ([^,]+)', line)url_match = re.search(r'URL: (https?://[^\s]+)', line)if not name_match or not url_match:return None, Nonereturn name_match.group(1), url_match.group(1)def classify_bookmark(bookmark_name, bookmark_url, categories):system_prompt = ("你是一个智能助手,任务是根据提供的书签名称和URL从给定的分类列表中选择最合适的分类返回给用户。仅返回分类名称。\n""请根据书签的内容和性质选择最适合的分类。如果没有合适的分类,请回答'无法分类'。\n""给定分类: {categories_str}\n""请选择最合适的分类。\n""示例:""user: 书签名称:Python官方文档\n""书签URL:https://docs.python.org/3/\n""assistant: 编程语言\n").format(categories_str=", ".join(categories))user_prompt = ("书签名称: {bookmark_name}\n""书签URL: {bookmark_url}\n").format(bookmark_name=bookmark_name, bookmark_url=bookmark_url)try:response = get_llm_response(system_prompt, user_prompt)except Exception as e:response = "其他"if response == "无法分类":return Nonereturn responsedef create_new_category(name, url):"""创建新分类:param name: 书签名称:param url: 书签URL:return: 新分类名"""system_prompt = ("你是一个智能助手,任务是根据提供的书签名称和URL给定一个合适的书签分类。仅返回分类名称。\n""请根据书签的内容和性质给定分类。\n""示例:""user: 书签名称:Python官方文档\n""书签URL:https://docs.python.org/3/\n""assistant: 编程语言\n")user_prompt = ("书签名称: {name}\n""书签URL: {url}\n").format(name=name, url=url)response = get_llm_response(system_prompt, user_prompt)return response# 使用配置中的分类规则
categories = CONFIG['DEFAULT_CATEGORIES']with open(CONFIG['EXTRACTED_FILE'], 'r', encoding='utf-8') as f:bookmarks = f.readlines()classified = defaultdict(list)
for line in bookmarks:if not line.strip():continuename, url = extract_bookmark_info(line)if not name or not url:continue# 分类书签category = classify_bookmark(name, url, categories)if not category:# 创建新分类category = create_new_category(name, url)categories.append(category)print(f'分类书签: {name} -> {category}')classified[category].append(line)# 将分类结果保存为文件
with open(CONFIG['CLASSIFIED_FILE'], 'w', encoding='utf-8') as f:f.write('# 书签\n\n')for category, items in classified.items():f.write(f'## {category}\n')for item in items:name, url = extract_bookmark_info(item)if name and url:f.write(f'- [{name}]({url})\n')f.write('\n')from datetime import datetime
# 将分类结果重新转为HTML书签文件
def md_to_netscape(md_content):# 初始化HTML结构html = '''<!DOCTYPE NETSCAPE-Bookmark-file-1><META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=UTF-8"><TITLE>Bookmarks</TITLE><H1>Bookmarks</H1><DL><p>'''# 解析MD内容lines = md_content.split('\n')stack = []current_level = 0for line in lines:# 处理标题if line.startswith('#'):level = line.count('#')title = line.lstrip('#').strip()# 关闭之前的DLwhile stack and stack[-1] >= level:html += '</DL><p>\n'stack.pop()# 添加H3标签html += f'    <DT><H3 ADD_DATE="{int(datetime.now().timestamp())}" LAST_MODIFIED="{int(datetime.now().timestamp())}">{title}</H3>\n'html += '    <DL><p>\n'stack.append(level)current_level = level# 处理链接elif line.startswith('-'):match = re.match(r'-\s*\[(.*?)\]\((.*?)\)', line)if match:name, url = match.groups()html += f'        <DT><A HREF="{url}" ADD_DATE="{int(datetime.now().timestamp())}">{name}</A>\n'# 关闭所有打开的DLwhile stack:html += '</DL><p>\n'stack.pop()return htmlwith open(CONFIG['CLASSIFIED_FILE'], 'r', encoding='utf-8') as f:md_content = f.read()html_content = md_to_netscape(md_content)with open(CONFIG['OUTPUT_FILE'], 'w', encoding='utf-8') as f:f.write(html_content)# 清理临时文件
def cleanup_temp_files():"""清理脚本运行过程中产生的临时文件"""temp_files = [CONFIG['EXTRACTED_FILE'],CONFIG['CLASSIFIED_FILE']]for file in temp_files:if os.path.exists(file):os.remove(file)print(f"已删除临时文件: {file}")# 主程序执行
if __name__ == '__main__':try:# 原有主逻辑代码...# 脚本执行完成后清理临时文件cleanup_temp_files()print("脚本执行完成,临时文件已清理")except Exception as e:print(f"脚本执行出错: {str(e)}")

相关文章:

浏览器书签智能分类

浏览器书签智能分类工具 最近发现浏览器的书签越来越乱了&#xff0c;主要是因为自己太懒&#xff0c;其次之前建的分类太多又乱&#xff0c;重新手动整理确实比较烦。因此有了这个小项目。借助智谱AI的力量对书签进行重新分类。 项目简介 本工具用于自动整理浏览器书签&…...

通俗易懂的讲一下Vue的双向绑定和React的单向绑定

1.Vue 的双向绑定&#xff1a; <template><!-- 输入框和数据自动绑定&#xff0c;就像连体婴儿&#xff0c;一个动另一个也动 --><input v-model"message"><p>{{ message }}</p><!-- 完整表单示例 --><form><!-- 所有…...

Redis 深度解析:从入门到精通

引言 Redis 是一个开源的、高性能的键值存储系统&#xff0c;它支持多种数据结构&#xff0c;并且提供了丰富的功能和接口。作为内存数据库&#xff0c;Redis 以其快速的数据访问速度、灵活的数据模型以及持久化选项而闻名。本文将详细介绍 Redis 的核心概念、工作原理及其应用…...

基于物联网的冻保鲜运输智能控制系统

基于物联网的冻保鲜运输智能控制系统设计文档 1. 项目开发背景 随着全球化贸易的发展&#xff0c;冷链物流在现代运输行业中扮演着日益重要的角色。尤其是冻品、食品、药品等对运输环境有着严格要求的货物&#xff0c;其运输过程中温度、湿度等环境参数必须严格控制&#xff…...

【深度学习基础之多尺度特征提取】多尺度卷积神经网络(MS-CNN)是如何在深度学习网络中提取多尺度特征的?附代码(二)

【深度学习基础之多尺度特征提取】多尺度卷积神经网络&#xff08;MS-CNN&#xff09;是如何在深度学习网络中提取多尺度特征的&#xff1f;附代码&#xff08;二&#xff09; 【深度学习基础之多尺度特征提取】多尺度卷积神经网络&#xff08;MS-CNN&#xff09;是如何在深度…...

论文解读之learning to summarize with human feedback

最近在看大模型训练相关的论文&#xff0c;预计会追溯经典的和最新的训练策略以及微调原理等 本次解读经典论文learning to summarize with human feedback 一、简介 部分生成任务需要对齐人类偏好&#xff0c;但是根据最大化可能性&#xff08;对数似然&#xff09;进行微调…...

STM32学习(六 )

串口初始化IO引脚 串口的引脚在哪里 串口可以利用GPIO_InitTypeDef结构体和GPIO_Init&#xff08;&#xff09;函数进行初始化 USART_InitTypeDef USART_InitStruct;//建立串口结构体USART_InitStruct.USART_BaudRate 115200;//波特率115200USART_InitStruct.USART_Mode US…...

基于 GitHub API 的 Issue 和 PR 自动化解决方案

文章目录 摘要引言优化 Issue 和 PR 管理的方法工具选择流程优化 自动化 Issue 和 PR 管理代码逻辑详解获取 Issue 数据为 Issue 添加标签将 Issue 分配给开发者主逻辑 实际运行效果进一步扩展QA 环节总结参考资料 摘要 在开源项目中&#xff0c;Issue 和 Pull Request&#x…...

56.在 Vue 3 中使用 OpenLayers 通过 moveend 事件获取地图左上和右下的坐标信息

前言 在现代 Web 开发中&#xff0c;地图应用越来越成为重要的组成部分。OpenLayers 是一个功能强大的 JavaScript 地图库&#xff0c;它提供了丰富的地图交互和操作功能&#xff0c;而 Vue 3 是当前流行的前端框架之一。在本篇文章中&#xff0c;我们将介绍如何在 Vue 3 中集…...

文件本地和OSS上传

这里写目录标题 前端传出文件后端本地存储阿里云OSS存储上传Demo实现上传ConfigurationProperties 前端传出文件 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>上传文件</title> </head&g…...

elementui table 表格 分页多选,保持选中状态

elementui多选时分页&#xff0c;解决选中状态无法保留选中项问题&#xff1a; 在el-table标签中加入row-key&#xff0c;row-key的值取当前数据里的唯一key在el-table-column selection 项中加入以下:reserve-selection“true” 完成后&#xff0c;将需要清空的地方 ( 如返回…...

MSE+Range案例

MSE的demo实现思路&#xff1a;首先准备fmp4格式的视频地址或者切片&#xff0c;接着将MSE挂载到video上&#xff0c;创建createObjectURL转二进制数据&#xff0c;fetch请求在线地址&#xff0c;分段请求&#xff0c;监听这个数据流的获取状态&#xff0c;当这个ReadyState为o…...

C# 设计模式(结构型模式):代理模式

C# 设计模式&#xff08;结构型模式&#xff09;&#xff1a;代理模式 在软件开发中&#xff0c;有时我们需要通过某种方式间接地访问一个对象&#xff0c;这时就可以使用代理模式&#xff08;Proxy Pattern&#xff09;。代理模式通过引入一个代理对象来控制对目标对象的访问…...

YOLO——pytorch与paddle实现YOLO

YOLO——pytorch与paddle实现YOLO 本文将深入探讨YOLO目标检测的理论基础&#xff0c;并通过PyTorch和PaddlePaddle两个深度学习框架来展示如何实现基础的YOLO模型。我们将首先介绍YOLO的基本概念&#xff0c;这些理论基础是理解和实现YOLO网络的基础。通过PyTorch和PaddlePad…...

持续大额亏损,销量增幅有限,北汽蓝谷依旧黯然神伤

撰稿 | 行星 来源 | 贝多财经 “起了个大早&#xff0c;赶了个晚集”&#xff0c;用在如今的北汽蓝谷身上再合适不过。 2025年的第一个工作日&#xff0c;北汽蓝谷新能源科技股份有限公司&#xff08;SH:600733&#xff0c;简称“北汽蓝谷”&#xff09;对外披露了子公司北京…...

C# OpenCV机器视觉:背景减除与前景分离

在实验室的一角&#xff0c;阳光仿若一个急性子的小精灵&#xff0c;迫不及待地穿过窗帘缝隙&#xff0c;在阿强的桌面上欢快跳跃&#xff0c;洒下一片片斑驳陆离的光影&#xff0c;似乎在催促着阿强赶紧开启今日的奇妙探索。阿强端坐在桌前&#xff0c;眼神炽热地盯着眼前那台…...

C语言return与 ? :

上次讲解过一次函数&#xff0c;函数要配合return返回东西&#xff0c;但是在编写一些程序的时候我发现了很多冷门逻辑语法还没有掌握&#xff0c;当时讲课也是看一眼就过去了&#xff08;死去的记忆开始攻击我&#xff09; Return&#xff0c;爽&#xff01; 现在有一个小问…...

【论文阅读】SCGC : Self-supervised contrastive graph clustering

论文地址&#xff1a;SCGC : Self-supervised contrastive graph clustering - ScienceDirect 代码地址&#xff1a; https://github.com/gayanku/SCGC 摘要 图聚类旨在发现网络中的群体或社区。越来越多的模型使用自编码器&#xff08;autoencoders&#xff09;结合图神经网…...

python pyqt5+designer的信号槽和动态显示

至少需要两个文件&#xff0c;一个是python的主文件&#xff0c;一个是designer的UI文件 1.对UI文件的处理 首先需要将UI文件转化成python文件&#xff0c;并且引入到主文件中。 2.在主文件中接受UI上的一些动作和返回主文件处理的数据到UI界面上。 框中选中的部分&#xff0c…...

版本控制系统Helix Core 2024.2增强功能:与OpenTelemetry协议集成、Delta同步和传输等

“Perforce团队非常高兴为您带来Helix Core 2024.2版本&#xff0c;它拥有众多旨在提高团队效率、优化工作流程的增强功能。通过新的Open Telemetry协议集成&#xff0c;团队现在可以轻松将结构化日志集成到可观测性平台中。DeltaTransfer现在也适用于同步操作——这是2024.1版…...

变量 varablie 声明- Rust 变量 let mut 声明与 C/C++ 变量声明对比分析

一、变量声明设计&#xff1a;let 与 mut 的哲学解析 Rust 采用 let 声明变量并通过 mut 显式标记可变性&#xff0c;这种设计体现了语言的核心哲学。以下是深度解析&#xff1a; 1.1 设计理念剖析 安全优先原则&#xff1a;默认不可变强制开发者明确声明意图 let x 5; …...

QMC5883L的驱动

简介 本篇文章的代码已经上传到了github上面&#xff0c;开源代码 作为一个电子罗盘模块&#xff0c;我们可以通过I2C从中获取偏航角yaw&#xff0c;相对于六轴陀螺仪的yaw&#xff0c;qmc5883l几乎不会零飘并且成本较低。 参考资料 QMC5883L磁场传感器驱动 QMC5883L磁力计…...

【磁盘】每天掌握一个Linux命令 - iostat

目录 【磁盘】每天掌握一个Linux命令 - iostat工具概述安装方式核心功能基础用法进阶操作实战案例面试题场景生产场景 注意事项 【磁盘】每天掌握一个Linux命令 - iostat 工具概述 iostat&#xff08;I/O Statistics&#xff09;是Linux系统下用于监视系统输入输出设备和CPU使…...

IoT/HCIP实验-3/LiteOS操作系统内核实验(任务、内存、信号量、CMSIS..)

文章目录 概述HelloWorld 工程C/C配置编译器主配置Makefile脚本烧录器主配置运行结果程序调用栈 任务管理实验实验结果osal 系统适配层osal_task_create 其他实验实验源码内存管理实验互斥锁实验信号量实验 CMISIS接口实验还是得JlINKCMSIS 简介LiteOS->CMSIS任务间消息交互…...

【学习笔记】深入理解Java虚拟机学习笔记——第4章 虚拟机性能监控,故障处理工具

第2章 虚拟机性能监控&#xff0c;故障处理工具 4.1 概述 略 4.2 基础故障处理工具 4.2.1 jps:虚拟机进程状况工具 命令&#xff1a;jps [options] [hostid] 功能&#xff1a;本地虚拟机进程显示进程ID&#xff08;与ps相同&#xff09;&#xff0c;可同时显示主类&#x…...

基于IDIG-GAN的小样本电机轴承故障诊断

目录 🔍 核心问题 一、IDIG-GAN模型原理 1. 整体架构 2. 核心创新点 (1) ​梯度归一化(Gradient Normalization)​​ (2) ​判别器梯度间隙正则化(Discriminator Gradient Gap Regularization)​​ (3) ​自注意力机制(Self-Attention)​​ 3. 完整损失函数 二…...

Webpack性能优化:构建速度与体积优化策略

一、构建速度优化 1、​​升级Webpack和Node.js​​ ​​优化效果​​&#xff1a;Webpack 4比Webpack 3构建时间降低60%-98%。​​原因​​&#xff1a; V8引擎优化&#xff08;for of替代forEach、Map/Set替代Object&#xff09;。默认使用更快的md4哈希算法。AST直接从Loa…...

Python+ZeroMQ实战:智能车辆状态监控与模拟模式自动切换

目录 关键点 技术实现1 技术实现2 摘要&#xff1a; 本文将介绍如何利用Python和ZeroMQ消息队列构建一个智能车辆状态监控系统。系统能够根据时间策略自动切换驾驶模式&#xff08;自动驾驶、人工驾驶、远程驾驶、主动安全&#xff09;&#xff0c;并通过实时消息推送更新车…...

C++ 设计模式 《小明的奶茶加料风波》

&#x1f468;‍&#x1f393; 模式名称&#xff1a;装饰器模式&#xff08;Decorator Pattern&#xff09; &#x1f466; 小明最近上线了校园奶茶配送功能&#xff0c;业务火爆&#xff0c;大家都在加料&#xff1a; 有的同学要加波霸 &#x1f7e4;&#xff0c;有的要加椰果…...

STM32---外部32.768K晶振(LSE)无法起振问题

晶振是否起振主要就检查两个1、晶振与MCU是否兼容&#xff1b;2、晶振的负载电容是否匹配 目录 一、判断晶振与MCU是否兼容 二、判断负载电容是否匹配 1. 晶振负载电容&#xff08;CL&#xff09;与匹配电容&#xff08;CL1、CL2&#xff09;的关系 2. 如何选择 CL1 和 CL…...