用 python 开发一个可调用工具的 AI Agent,实现电脑配置专业评价
在人工智能时代,AI Agent凭借其强大的任务处理能力,逐渐成为开发人员手中的得力工具。今天,我们就来一起动手,用Python打造一个能够调用工具的AI Agent,实现根据电脑信息对电脑配置进行专业评价的功能。
一、项目创建与目录结构
1.1 项目创建
首先,我们需要创建一个新的项目环境。这里使用UV进行项目创建。
uv init demo
项目创建完成后,进入项目文件夹并安装必要的包, 比如安装psutil
uv add psutil
安装的包都会记录在pypoject.toml, 看看我都安装了哪些包
[project]
name = "demo"
version = "0.1.0"
description = "Add your description here"
readme = "README.md"
requires-python = ">=3.12"
dependencies = ["psutil>=7.0.0","pydantic-ai>=0.2.16","python-dotenv>=1.1.0","setuptools>=80.9.0",
]
1.2 目录结构
我们的项目目录结构如下:
demo
├── .venv
├──.env
├──.gitignore
├──.python-version
├── main.py
├── pyproject.toml
├── README.md
├── tools.py
├── uv.lock
可以看到除了创建项目时uv自动创建的文件及文件夹,这个项目我主要创建了3个文件:
main.py
:项目的主程序文件,负责整个AI Agent的运行逻辑,包括模型初始化、与AI交互以及结果处理等核心功能。tools.py
:存放读取电脑配置信息的工具函数,为main.py
提供电脑配置数据支持。.env
:用于存储敏感信息,此项目主要存储了OPENROUTER_API_KEY
,保证API密钥的安全,避免在代码中直接暴露。
二、功能实现与代码解析
2.1 读取电脑配置信息(tools.py)
在tools.py
文件中,我定义了read_pc_info
函数,用于获取电脑的详细配置信息。该函数的实现依赖platform
和psutil
库。
import platform
import psutildef read_pc_info():# 获取系统信息info = []# CPU信息info.append(f"CPU: {platform.processor()}")info.append(f"CPU Cores: {psutil.cpu_count(logical=False)} physical, {psutil.cpu_count(logical=True)} logical")# 内存信息mem = psutil.virtual_memory()info.append(f"RAM: {mem.total / (1024**3):.1f} GB (Available: {mem.available / (1024**3):.1f} GB)")# 磁盘信息partitions = psutil.disk_partitions()for p in partitions:if p.fstype:usage = psutil.disk_usage(p.mountpoint)info.append(f"Disk {p.device}: {usage.total / (1024**3):.1f} GB ({usage.percent}% used)")# 操作系统信息info.append(f"OS: {platform.system()} {platform.release()}")return "\n".join(info)
- CPU信息获取:使用
platform.processor()
获取CPU型号,psutil.cpu_count(logical=False)
获取物理核心数,psutil.cpu_count(logical=True)
获取逻辑核心数。 - 内存信息获取:通过
psutil.virtual_memory()
获取系统内存相关信息,包括总内存和可用内存,并进行单位换算后添加到info
列表。 - 磁盘信息获取:
psutil.disk_partitions()
获取磁盘分区信息,遍历分区,使用psutil.disk_usage(p.mountpoint)
获取每个分区的使用情况,添加到info
列表。 - 操作系统信息获取:
platform.system()
获取操作系统名称,platform.release()
获取操作系统版本号,将其组合添加到info
列表。最后,将info
列表中的所有信息以换行符连接成字符串返回。
2.2 主程序逻辑(main.py)
在main.py
文件中,包含了项目的核心运行逻辑。
2.2.1 导入需要的库和定义系统提示词
import os
from typing import Optional, Tuple
from dotenv import load_dotenv
from openai import OpenAI
from pydantic_ai import Agent
from pydantic_ai.models.openai import OpenAIModel
from pydantic_ai.providers.openai import OpenAIProvider
from tools import read_pc_info
import logging# 系统提示词定义
SYSTEM_PROMPT = """
你是一位专业的电脑硬件评测专家,擅长分析电脑配置的性能、适用性和升级潜力。你能够根据用户提供的电脑配置信息,给出专业、实用的评价和建议。请以简洁明了的语言表达观点,既要考虑技术细节,也要考虑普通用户的理解能力。
"""
这里先导入了项目所需的各种库,定义了SYSTEM_PROMPT
常量,用于设定AI Agent的角色和能力,让其以专业电脑硬件评测专家的身份进行回答。
2.2.2 获取API配置
def get_api_config() -> Tuple[str, str]:"""获取OpenRouter API配置返回:Tuple[str, str]: (api_key, base_url) API密钥和基础URL异常:ValueError: 当API密钥未设置时EnvironmentError: 当.env文件加载失败时"""try:if not load_dotenv():logging.warning(".env文件未找到或加载失败")api_key = os.getenv("OPENROUTER_API_KEY")base_url = 'https://openrouter.ai/api/v1'if not api_key:raise ValueError("请在.env文件中设置OPENROUTER_API_KEY")return api_key, base_urlexcept Exception as e:logging.error(f"获取API配置失败: {e}")raise
该函数负责从.env
文件中加载OPENROUTER_API_KEY
,并返回API密钥和base_url(因为我用的是openrouter里的模型,所以需要base_url这个参数)。 如果.env
文件加载失败或API密钥未设置,会抛出相应的异常。
2.2.2 初始化模型
def initialize_model() -> OpenAIModel:"""初始化AI大模型实例返回:OpenAIModel: 初始化好的模型实例异常:RuntimeError: 当模型初始化失败时"""try:api_key, base_url = get_api_config()provider = OpenAIProvider(base_url=base_url, api_key=api_key)return OpenAIModel('qwen/qwen-2.5-72b-instruct:free',provider=provider)except Exception as e:logging.error(f"模型初始化失败: {e}")raise RuntimeError("无法初始化AI模型") from e
此函数通过调用get_api_config
获取API配置,然后使用OpenAIProvider
和指定的模型名称(这里我选的是免费的qwen/qwen-2.5-72b-instruct:free
)初始化OpenAIModel
实例。如果初始化过程中出现错误,会记录错误日志并抛出RuntimeError
。
2.2.4 主函数逻辑
def main():# 配置日志记录logging.basicConfig(level=logging.INFO,format='%(asctime)s - %(levelname)s - %(message)s')try:model = initialize_model()logging.info("AI模型初始化成功")except Exception as e:logging.error(f"连接大模型错误: {e}")returntry:pc_info = read_pc_info()logging.info("成功获取电脑配置信息")logging.info("电脑配置信息:\n" + pc_info)except Exception as e:logging.error(f"获取配置信息出错: {e}")return# 构建用户提示词user_prompt = f"""我需要您对这台电脑的配置进行全面评价。请分析以下几点:1. 这台电脑的性能是否能够满足日常办公、网页浏览、视频播放等基本需求2. 是否适合运行更复杂的应用程序,如视频编辑、游戏或编程3. 从性价比角度考虑,是否有必要升级某些硬件组件4. 如果需要升级,您推荐升级哪些组件,预算大约是多少5. 如果不值得升级,您认为在什么情况下应该考虑更换新电脑按照指定格式给出专业评测:1. 使用简洁清晰的中文回答;2. 回答必须使用标准 Markdown 格式,例如:## 标题、- 列表项;3. 不要包含任何乱码、HTML 标签、JavaScript 代码或特殊符号;4. 避免出现“(注:...)”这类解释性括号内容;5. 输出应易于阅读且结构清晰。以下是我的电脑配置信息:{pc_info}"""# 创建AI代理agent = Agent(model,system_prompt=SYSTEM_PROMPT)# 调用模型获取评价response = agent.run_sync(user_prompt)# 打印结果logging.info("电脑配置评价结果:")logging.info(response)if __name__ == "__main__":main()
在main
函数中:
- 首先配置日志记录,设置日志级别为
INFO
,指定日志格式。 - 调用
initialize_model
初始化AI模型,若成功则记录日志,失败则记录错误日志并返回。 - 调用
read_pc_info
获取电脑配置信息,成功则记录配置信息日志,失败记录错误日志并返回。 - 根据获取的电脑配置信息构建
user_prompt
,明确告知AI Agent需要评价的内容和格式要求。 - 使用初始化的模型和
SYSTEM_PROMPT
创建Agent
实例。 - 通过
agent.run_sync(user_prompt)
调用AI Agent,传入用户提示词,获取电脑配置评价的响应。 - 最后获得返回的结果
三、结果展示
运行该项目后,在控制台会输出电脑配置信息获取过程、AI 模型交互过程的日志信息,最终展示处理后的电脑配置评价结果。
- 工具(read_pc_info函数)获得的信息
将工具获得的信息和提示词给大模型后,大模型返回的结果
因为提示词中我们说明了要Markdown格式,所以把‘\n’转成实际的换行,就更容易读了
## 电脑配置详细评测### 1. 基本需求
根据您提供的配置信息,以下是对这台电脑性能的分析:
- **CPU**:Intel64 Family 6 Model 142 Stepping 10, 4核心8线程,这是一颗中等档次的处理器,型号可能是Intel Core i5-8250U(根据提供的信息推测)。对于日常办公、网页浏览和视频播放等基本需求来说,这块处理器已经非常足够,能够保证流畅的使用体验。
- **内存**:19GB,但可用的为8GB。内存方面有些不足,8GB对于现代操作系统和多任务处理来说略显紧张。建议将内存提升至16GB,这将显著改善多任务处理能力和软件运行效率。
- **硬盘**:三个硬盘分区,C盘200GB已用66.1%,表明系统分区负载较重。D盘和E盘相对空闲,仍可满足存储需求。
- **OS**:Windows 11 对系统性能有一定需求,您的电脑配置可以支持,但会感觉到一些性能瓶颈,尤其是在内存方面。### 2. 复杂应用程序
- **视频编辑**:这块CPU和8GB内存对于视 频编辑来说有些吃力,处理高清视频时可能会遇到卡顿和较高的延迟,不推荐用于专业视频编辑。
- **游戏**:没有提供显卡信息,保守估计内置集显(如Intel UHD Graphics 620)。对于要求不高的游戏,该配置勉强可以运行,但无法流畅玩大型3D游戏。
- **编程**:日常编写代码和运行轻量级开发环境(如Web开发)可以胜任,但在处理大型项 目或资源密集型编译时可能会感到力不从心。### 3. 性价比与升级建议
从性价比角度来看,对这台电脑硬件 进行合理升级可以提高其性能和使用寿命,建议如下:
- **内存升级**:将内存从8GB提升至16GB或更高,成本相 对较低但效果显著,预算约为300-500元。
- **SSD**:如果C盘使用的是HDD,考虑更换为1TB或更大容量的NVMe SSD ,这将大幅提升系统的启动速度和程序加载速度,预算约800-1500元。### 4. 升级推荐
- **升级内存**:增 加至16GB,预算300-500元。
- **升级SSD**:如果目前使用的是HDD,强烈建议更换为1TB NVMe SSD,以极大地提高 数据读写速度,预算800-1500元。### 5. 更换新电脑
如果上述升级措施仍无法满足您的需求,或者您希望获 得更高的性能和更长的使用寿命,建议考虑替换整机,特别是当您需要进行高负载的工作(如专业视频编辑、3D建模和高端游戏)时。更换新电脑的情况包括:
- **性能瓶颈**:尽管通过硬件升级,整体性能有所提升,但在某些特定任务中仍然感觉卡顿或延迟较高。
- **技术落伍**:当前的硬件架构已经无法支持最新的软件和技术,如AI加速、实时光线追踪等。
- **性价比过低**:升级的成本已经接近于购买新电脑,或者升级后的性能提升不明显。
我们创建的AI Agent就完成了。
我试了几个openrouter支持调用工具的免费大模型,只有这个大模型说对了CPU型号,但是它对内存的评价不是很准确,虽然明知道是20G内存,其中8G可用,还建议我升级到16G(我的电脑运行了太多的程序,打开了太多的网页,所以20G的内存,只剩8G可用)。因为我们的工具没有给出硬盘的详细型号,所以大模型给的建议参考价值就不大了,看来要改进工具函数获取更详细的信息。
四、项目总结与优化方向
这个项目展示了如何使用Python创建一个能够调用工具的AI Agent,实现电脑配置的自动评估。通过结合系统工具与大语言模型的能力,我们构建了一个简单但实用的应用场景。
在实际使用中,我发现大模型在某些方面的判断还不够准确,比如对内存的评估就没有考虑到当前系统的负载情况。这也提醒我们,即使是强大的AI模型,也需要合理的提示词设计和数据预处理,才能得到更准确的结果。当然,另一方也需要工具能够提供尽可能详细的信息给到大模型,才能帮助大模型做出更准备的判断和更有价值的建议。
未来,我们可以从以下几个方面优化这个项目:
- 增强工具功能:可以添加更多的系统信息收集功能,如GPU信息、网络速度测试等
- 改进提示词:针对大模型可能出现的误解,优化提示词设计,提供更明确的指导
- 多模型对比:增加模型选择功能,对比不同模型的输出结果,选择最准确的评估
- 用户交互优化:添加图形界面或Web界面,提升用户体验
- 增加评估维度:除了硬件性能,还可以评估系统健康状态、安全配置等方面
通过这个项目,我们不仅学习了如何构建一个AI Agent,更重要的是理解了如何将大模型与实际工具结合,创造出真正有价值的应用。AI Agent的潜力巨大,随着技术的不断发展,我们可以期待更多创新应用的出现。
如果你也想尝试这个项目,只需按照本文的步骤操作,就能轻松构建出自己的电脑配置评估AI Agent。希望这个项目能为你提供一些启发,帮助你探索更多AI Agent的应用场景。
相关文章:
用 python 开发一个可调用工具的 AI Agent,实现电脑配置专业评价
在人工智能时代,AI Agent凭借其强大的任务处理能力,逐渐成为开发人员手中的得力工具。今天,我们就来一起动手,用Python打造一个能够调用工具的AI Agent,实现根据电脑信息对电脑配置进行专业评价的功能。 一、项目创建…...
Java自定义线程池(ThreadPoolExecutor)
Java线程池使用示例 下面将展示如何使用自定义线程池(ThreadPoolExecutor)来执行任务,包括提交Runnable任务、Callable任务,处理拒绝策略以及关闭线程池。 import java.util.concurrent.*;public class ThreadPoolDemo {// 自定义线程工厂(…...
386. 字典序排数
386. 字典序排数 理解题目要求 题目要求我们生成从 1 到 n 的整数的字典序排列,并且要求: 时间复杂度 O(n):不能使用直接排序(通常指的是使用标准的排序算法(如快速排序、归并排序、堆排序等)对数…...
Kaggle-Plant Seedlings Classification-(多分类+CNN+图形处理)
Plant Seedlings Classification 题意: 就是给出很多图片,预测出图片中的小草是什么类型的。 数据处理: 1.去除图片背景,只保留物体。 2.图片数据加强。 建立模型: 1.CNN的Sequential(),多层卷积块和…...
Android 应用多语言与系统语言偏好设置指南
文章目录 创建语言包以中文包为例 以系统为主导的“应用语言偏好设置”从你的应用调到“应用语言偏好设置” 创建语言包 我们可以使用一个很蹩脚的办法来实现: 以中文包为例 values是默认values-zh-rCN是简体中文values-zh-rTW是繁体(台湾省ÿ…...
Excel学习01
Excel是微软公司开发的一款电子表格软件,可以广泛应用于数据处理、统计分析、图表制作、财务管理和自动化办公领域等。Excel在实际工作中使用的非常广泛,为此本次开始针对excel的使用进行一系列讲解。 展示使用的软件是WPS,它和excel的使用方…...
Loggers 配置解析(log4j.xml)
Loggers 配置解析 我们通过下面的例子来理解 log4j 的 Loggers 配置是如何决定日志输出规则的。 <Loggers><!-- 根Logger:全局配置 --><Root level"debug"><AppenderRef ref"consoleAppender" level"info"/&g…...
Matplotlib 绘图库使用技巧介绍
目录 前言 Matplotlib 简介 快速入门 图形结构解剖 常用绘图函数 子图与布局 单行多列子图: 网格布局: 自定义位置: 样式与标注 中文字体与科学计数 图例、网格、坐标轴 动态图与动画 三维绘图 常见问题与技巧 前言 Matplotli…...
服务器如何从http升级到https(nginx)
1.证书申请 可以到阿里云或者华为云去申请证书,申请完下载证书是个压缩包,然后解压 可以到到几个文件夹,找到 .Nginx 文件夹打开 会有两个文件,将这两个文件上传至nginx/conf/cert文件夹下(cert需要手…...
解决戴尔电脑No bootable devices found问题
解决戴尔电脑No bootable devices found问题 一、调整BIOS设置 1、在关机状态下,打开计算机电源,在出现 Dell 徽标时按 F2 键以引导至 BIOS 设置菜单。 2、选择 Boot sequence(引导顺序 )并将选项从 Legacy(传统 &…...
FPGA基础 -- Verilog 行为级建模之条件语句
Verilog 的行为级建模(Behavioral Modeling)中的条件语句(Conditional Statements),逐步从基础到实际工程应用,适合有RTL开发基础但希望深入行为建模的人。 一、行为级建模简介 行为级建模(Beh…...
最大公约数
题目描述 输入两个正整数a,b,求a,b的最大公约数。 输入 输入正整数a和b,中间用空格隔开 输出 输出最大公约数 样例输入 144 84样例输出 12程序分析 :运用辗转相除法(欧几里得算法) 用较大数除以较小数,取余数;…...
springboot入门之路(一)
文章目录 1.Spring Boot介绍2.开发你的第一个Spring Boot应用2.1创建POM2.2yml和properties的配置区别yml配置properties配置 2.3springbootDemo代码2.4创建一个可执行jar 参考文档:SpringBoot参考指南;SpringBoot实战 1.Spring Boot介绍 Spring Boot使…...
vue | vue 插件化机制,全局注册 和 局部注册
组件插件化:提升组件的可复用性、扩展性和独立性 组件插件化实现方式 ├── 注册机制 │ ├── 全局注册(app.use)→ install, 循环注册, 配置项 │ └── 局部注册(import components) │ ├── 插件化能力…...
技术与情感交织的一生 (八)
目录 融合 东西厂公 接风宴 头痛 “巴巴罗萨” 突击 推进 助攻 96小时 寒冬 食堂 反攻 消耗 Delphi 西厂 内困 外患 “敦刻尔克” 多线作战 大撤退 资源 融合 东西厂公 初次来到纸箱厂,是主厂区,感觉很大,相对西面正在…...
基于python的web系统界面登录
#让我们的电脑可以支持服务访问 #需要一个web框架 #pip install Flask from flask import Flask, render_template,request from random import randint app Flask(__name__) app.route(/index) def index():uname request.args.get("uname")return f"主页&am…...
利用Java进行验证码的实现——算数验证码
我主要使用使用 Java Swing 库创建一个 GUI 窗口,然后在窗口中显示生成的算术验证码图片,并提供一个文本框和一个按钮,输入验证码并验证显示结果。 代码如下: package calculate; import javax.swing.*; import java.awt.*; imp…...
OpenStack入门体验
1.1云计算概述 相信大家都听到很多的阿里云、腾讯云、百度云等等这些词,那到底什么是云计算?云 计算又能做什么? 1.1.1什么是云计算 云计算(cloud computing)是一种基于网络的超级计算模式,基于用户的不同需求,提供所需的资源,包括计算资源、存储资源、网络资源等。云计算…...
实时中值滤波 + 低通滤波 示例程序(STM32环境)
一、功能概述 本示例实现两个滤波器: 中值滤波器(Median Filter):对短期异常值(如尖峰噪声)有良好的抑制能力;低通滤波器(Low-Pass Filter):对数据进行平滑…...
AppBarLayout+ CoordinatorLayout,ViewPager2为什么不会覆盖AppBarLayout
<?xml version"1.0" encoding"utf-8"?> <layout xmlns:android"http://schemas.android.com/apk/res/android"xmlns:app"http://schemas.android.com/apk/res-auto"xmlns:tools"http://schemas.android.com/tools&quo…...
C语言——枚举
目录 一、枚举的基本概念 1. 定义与语法 2. 枚举变量的声明 二、枚举的特性 1. 整型常量的本质 2. 作用域规则 3. 内存占用 三、枚举的使用场景 1. 替代宏定义常量 2. 状态机实现 3. 函数返回值类型 四、枚举与其他类型的对比 五、高级技巧与注意事项 1. 位掩码枚…...
148. 排序链表
题目: 给你链表的头结点 head ,请将其按 升序 排列并返回 排序后的链表 。 示例1: 解题思路: 这道题是一道综合题,考察了链表中间节点合并有序链表。首先我们链表中间节点,然后从中间结点的前一个节点处断…...
26.【.NET8 实战--孢子记账--从单体到微服务--转向微服务】--单体转微服务--角色权限管理
在现代企业级应用中,角色权限管理是保障系统安全和提升用户体验的核心基础功能。一个高效的角色权限系统不仅能够有效防止越权访问,还能简化系统的维护和扩展。本文将系统性介绍角色权限管理的核心实现思路,包括架构设计、性能优化、安全机制…...
flowable查询最新定义的流程梳理
背景。使用ruoyi-flowable-plus进行二次开发。将项目与流程绑定后查询相关流程表单时发现问题。于是梳理逻辑汇总了下面的思维导图和相关代码。查询逻辑。流程定义Key 最流程新版本(orderByProcessDefinitionVersion) 取第一条流程实例 最新的一条版本记录。这里一定要用流程…...
kafka消费的模式及消息积压处理方案
目录 1、kafka消费的流程 2、kafka的消费模式 2.1、点对点模式 2.2、发布-订阅模式 3、consumer消息积压 3.1、处理方案 3.2、积压量 4、消息过期失效 5、kafka注意事项 Kafka消费积压(Consumer Lag)是指消费者处理消息的速度跟不上生产者发送消息的速度,导致消息在…...
基于多模态文档解析与RAG的行业知识库构建技术指南
1. 技术背景 随着企业非结构化数据(扫描件、PDF、图像等)占比超过80%,传统关键词检索已无法满足精准问答需求。本文提出融合**计算机视觉(CV)与大语言模型(LLM)**的解决方案,关键技…...
UVa1408/LA4018 Flight Control
UVa1408/LA4018 Flight Control 题目链接题意分析AC 代码 题目链接 本题是2007年icpc亚洲区域赛成都赛区的F题 题意 有一个N行M列的数组(1 ≤ N ≤ 50, 1 ≤ M ≤ 9)记录机场各个航班的飞行传感数据,其每个元素都是整数。如果某元素小于等于0,则其一定不…...
【STM32 HAL库】使用HAL库操作FLASH
操作顺序 先解锁Flash,再擦除片区,再写入,写完了别忘了加锁。 HAL_FLASH_Unlock(); HAL_FLASHEx_Erase(); HAL_FLASH_Program(); HAL_FLASH_Lock();擦除操作 首先有个问题,我们为什么要擦除,不能直接覆写吗…...
【学习笔记】2.2 Encoder-Decoder
参考资料:https://github.com/datawhalechina/happy-llm 在 Transformer 中,使用注意力机制的是其两个核心组件——Encoder(编码器)和 Decoder(解码器)。 2.2.1 Seq2Seq 模型 Seq2Seq(序列到…...
批量创建tmux tmux批量
目录 获取空进程 tmux 获取空进程tmux并关闭 批量创建tmux 批量创建tmux 设置CUDA_VISIBLE_DEVICES: python 读取CUDA_VISIBLE_DEVICES 获取空进程 tmux for session in $(tmux ls -F #S); dopid=$(tmux list-panes -t "$session" -F "#{pane_pid}"…...
7.索引库操作
mapping映射属性 mapping是对索引库中文档的约束 常见的mapping属性包括: type 字段数据类型,常见的简单类型有: 字符串:text(可分词的文本) keyword(精确值,例如:品牌、国家,ip地址) 数值&…...
Transformer-BiGRU、Transformer、CNN-BiGRU、BiGRU、CNN五模型多变量时序预测
Transformer-BiGRU、Transformer、CNN-BiGRU、BiGRU、CNN五模型多变量时序预测 目录 Transformer-BiGRU、Transformer、CNN-BiGRU、BiGRU、CNN五模型多变量时序预测预测效果基本介绍程序设计参考资料 预测效果 基本介绍 Transformer-BiGRU、Transformer、CNN-BiGRU、BiGRU、CN…...
ROS2 笔记汇总(2) 通信接口
在 ROS 系统中,通信接口(Interface) 是节点之间传递信息的标准“语言协议”,确保了不同功能节点之间可以正确理解和使用彼此传送的数据内容。我们可以将其理解为“数据结构格式定义”,贯穿于话题(Topic&…...
更新已打包好的 Spring Boot JAR 文件中的 class 文件
# 1. 解压原始 JAR unzip -q original-app.jar -d temp # 2. 替换 class 文件 cp ~/projects/new-classes/*.class temp/BOOT-INF/classes/com/example/ # 3. 保留原始清单 cp temp/META-INF/MANIFEST.MF . # 4. 重新打包 jar -cf0m new-app.jar MANIFEST.MF -C temp/ . # …...
matlab实现求解兰伯特问题
求解兰伯特问题的matlab代码,非常好用 solve_lambertLYP.m , 1899 StumpffC.m , 136 StumpffdF.m , 294 StumpffF.m , 151 StumpffS.m , 167 Stumpffy.m , 96 text2.m , 104...
英福康INFICON VGC501, VGC502, VGC503 单通道、双通道和三通道测量装置
英福康INFICON VGC501, VGC502, VGC503 单通道、双通道和三通道测量装置...
解决IDEA插件使用Lombok找不到符号问题
https://juejin.cn/post/7013998800842784782 -Djps.track.ap.dependenciesfalse...
ULVAC DC-10-4P 400V input 10kW DC Pulse power supply 爱发科直流电源
ULVAC DC-10-4P 400V input 10kW DC Pulse power supply 爱发科直流电源...
pip安装python第三方库报错
ERROR: Could not install packages due to an OSError: [WinError 32] 另一个程序正在使用此文件,进程无法访问。: C:\\Users\\Lenovo\\AppData\\Local\\Temp\\pip-unpack-9i5hs6ml\\tensorflow-2.10.1-cp310-cp310-win_amd64.whl Consider using the --user optio…...
湖南大学CS-2024期末考试解析
【前言】 这是一张引流贴,标准答案跳转至23级同学的博客。 但需要指出,本人没来得及校准答案。 感谢23级同学做出的开源贡献。 【参考答案】 湖南大学CS-2024期末考试解析-CSDN博客...
SpringBoot-Thymeleaf
大佬写的真好:Thymeleaf一篇就够了-阿里云开发者社区...
Docker镜像之windows系统
https://github.com/dockur/windows 在 Docker 容器中运行 Windows 功能 ISO 下载器KVM 加速基于网页的查看器 使用方法 启动容器并通过浏览器连接到端口 8006。整个安装过程将全自动完成,无需手动干预。当桌面界面出现时,表示 Windows 安装已完成&a…...
学到新的日志方法mp
使用mp技术的时候可以在类上加上注解Slf4j 就可以使用日志 不需要在定义变量log,注意日志只能在方法内使用,不能在方法外进行使用...
PythonWeb项目开发脚手架
项目技术选型 1、FastAPI python web开发框架 2、SQLAlchemy ORM框架 (MySQL) 3、Dynaconf 配置管理 4、JWT Passlib(hash加密) 码云地址: pyhappy: Python Web 项目开发脚手架...
相机--相机标定
教程 相机标定分类 相机标定分为内参标定和外参标定。 内参标定 目的 作用 原理 外参标定...
IoTGateway项目生成Api并通过swagger和Postman调用
IoTGateway项目生成Api并通过swagger和Postman调用-CSDN博客...
vscode code runner 使用python虚拟环境
转载如下: zVS Code插件Code Runner使用python虚拟环境_coderunner python-CSDN博客...
IEE754标准,double和int转换,在线计算器
1.在线计算器 在线进制转换-IEE754浮点数16进制转换 2.标准解释 西门子PLC接收的ModbusRTU数据帧中IEEE754 格式4字节数据转为浮点数转换程序_西门子modbus读取32位浮点数-CSDN博客 浮点数表示(IEEE 754)_浮点数举个例子-CSDN博客 IEEE754 浮点数&a…...
语音转文字工具
平时工作和学习比较忙,可能没时间听讲座,只能看回放,回访也很长,这时,我们可以借助语言转文字,通过阅读文字快速了解讲座的重点,今天给大家分享一个本人经常用的语言转文字工具,改工…...
微前端之micro-app数据通信
在这之前如果还没接触过微前端,可以找一些视频、资料先去了解一下,就不在这里赘述了。 现在常见的微前端框架包括: single-spa micro-app qiankun EMP 无界 目前了解到的基本上是这些哈,大家感兴趣可以自行去了解一下,看下它们之间的区别。 因为我目前使用的是mic…...