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

AI写程序:图片批量重命名工具 - 自动化整理您的图片库

图片批量重命名工具 - 自动化整理您的图片库

GitHub项目地址: https://github.com/dependon/renameImage

项目介绍

这是一个基于Python开发的图形界面工具,用于批量重命名文件夹中的图片文件。它能够递归处理选定文件夹及其所有子文件夹中的图片,按照"文件夹名_序号.扩展名"的格式进行智能重命名。

主要功能

  • 递归处理: 自动扫描并处理选定文件夹及其所有子文件夹
  • 智能重命名: 将图片重命名为"文件夹名_序号.扩展名"的统一格式
  • 多语言支持: 提供7种语言界面(中文、英文、俄语、日语、德语、葡萄牙语和法语)
  • 实时日志: 显示详细的处理进度和结果
  • 用户友好: 简洁直观的图形界面,操作简单

支持的图片格式

  • JPG/JPEG
  • PNG
  • GIF
  • BMP
  • TIFF
  • WEBP

技术实现

项目主要使用Python标准库开发,无需额外安装第三方库。核心功能包括:

  1. 递归文件处理: 使用os.walk遍历文件夹结构
  2. 多语言支持: 通过JSON文件存储翻译文本,动态加载
  3. 线程处理: 使用threading模块防止界面卡顿
  4. GUI界面: 基于tkinter构建用户友好的图形界面

完整代码

# rename_images_gui.py
import os
import tkinter as tk
from tkinter import filedialog, messagebox, scrolledtext, ttk
import threading
from language_manager import LanguageManagerSUPPORTED_EXTENSIONS = {'.jpg', '.jpeg', '.png', '.gif', '.bmp', '.tiff', '.webp'}# --- 核心重命名逻辑 ---
def rename_images_in_folder(folder_path, log_callback):try:folder_name = os.path.basename(folder_path)if not folder_name:log_callback(lang_manager.get_text('skip_root').format(folder_path=folder_path))return 0count = 1renamed_count = 0log_callback(lang_manager.get_text('start_processing').format(folder_path=folder_path))items = sorted(os.listdir(folder_path))for filename in items:original_full_path = os.path.join(folder_path, filename)if os.path.isfile(original_full_path):_, ext = os.path.splitext(filename)if ext.lower() in SUPPORTED_EXTENSIONS:new_filename = f"{folder_name}_{count}{ext}"new_full_path = os.path.join(folder_path, new_filename)if original_full_path == new_full_path:log_callback(lang_manager.get_text('skip_same_name').format(filename=filename))count += 1continueelif os.path.exists(new_full_path):log_callback(lang_manager.get_text('warning_existing_file').format(filename=filename, new_filename=new_filename))continuetry:os.rename(original_full_path, new_full_path)log_callback(lang_manager.get_text('success').format(filename=filename, new_filename=new_filename))renamed_count += 1count += 1except OSError as e:log_callback(lang_manager.get_text('error_rename').format(filename=filename, error=str(e)))log_callback(lang_manager.get_text('folder_processed').format(folder_path=folder_path, renamed_count=renamed_count))return renamed_countexcept Exception as e:log_callback(lang_manager.get_text('unexpected_error').format(error=str(e)))return 0def rename_images_recursively(root_dir, log_callback):total_renamed = 0if not os.path.isdir(root_dir):log_callback(lang_manager.get_text('invalid_folder_error'))return 0log_callback(lang_manager.get_text('recursive_start').format(root_dir=root_dir))for dirpath, dirnames, filenames in os.walk(root_dir, topdown=True):renamed_in_folder = rename_images_in_folder(dirpath, log_callback)total_renamed += renamed_in_folderlog_callback(lang_manager.get_text('recursive_complete').format(total_renamed=total_renamed))return total_renamed# --- GUI 部分 ---
class RenamerApp:def __init__(self, master):self.master = masterself.lang_manager = LanguageManager()self.update_window_title()self.selected_folder = tk.StringVar()self.is_running = False# 创建语言选择下拉框self.create_language_selector()# 文件夹选择部分tk.Label(master, text=self.lang_manager.get_text('select_folder')).grid(row=1, column=0, padx=5, pady=5)self.folder_entry = tk.Entry(master, textvariable=self.selected_folder, width=50, state='readonly')self.folder_entry.grid(row=1, column=1, padx=5, pady=5, sticky="ew")self.browse_button = tk.Button(master, text=self.lang_manager.get_text('browse'), command=self.browse_folder)self.browse_button.grid(row=1, column=2, padx=5, pady=5)# 开始按钮self.rename_button = tk.Button(master, text=self.lang_manager.get_text('start_rename'), command=self.start_renaming_thread)self.rename_button.grid(row=2, column=0, columnspan=3, padx=5, pady=10)# 日志区域tk.Label(master, text=self.lang_manager.get_text('log')).grid(row=3, column=0, padx=5, pady=5, sticky="w")self.log_area = scrolledtext.ScrolledText(master, wrap=tk.WORD, height=15, width=70)self.log_area.grid(row=4, column=0, columnspan=3, padx=5, pady=5, sticky="nsew")self.log_area.config(state='disabled')# 布局配置master.grid_columnconfigure(1, weight=1)master.grid_rowconfigure(4, weight=1)def create_language_selector(self):languages = self.lang_manager.get_supported_languages()current_lang = self.lang_manager.get_current_language()frame = tk.Frame(self.master)frame.grid(row=0, column=0, columnspan=3, padx=5, pady=5, sticky="e")# 获取当前语言的本地化名称current_lang_name = languages[current_lang]self.lang_var = tk.StringVar(value=current_lang_name)# 创建语言代码到本地化名称的映射self.lang_code_to_name = languagesself.lang_name_to_code = {v: k for k, v in languages.items()}self.lang_combobox = ttk.Combobox(frame, textvariable=self.lang_var, values=list(languages.values()), state='readonly', width=10)self.lang_combobox.bind('<<ComboboxSelected>>', self.on_language_change)self.lang_combobox.pack(side=tk.RIGHT)def on_language_change(self, event=None):selected_lang_name = self.lang_var.get()selected_lang_code = self.lang_name_to_code[selected_lang_name]if self.lang_manager.load_language(selected_lang_code):self.update_ui_texts()def update_ui_texts(self):self.update_window_title()self.browse_button.config(text=self.lang_manager.get_text('browse'))self.rename_button.config(text=self.lang_manager.get_text('start_rename') if not self.is_running else self.lang_manager.get_text('processing'))# Update label textsfor widget in self.master.grid_slaves():if isinstance(widget, tk.Label):if widget.grid_info()['row'] == 1:  # Select folder labelwidget.config(text=self.lang_manager.get_text('select_folder'))elif widget.grid_info()['row'] == 3:  # Log labelwidget.config(text=self.lang_manager.get_text('log'))def update_window_title(self):self.master.title(self.lang_manager.get_text('title'))def log(self, message):def _update_log():self.log_area.config(state='normal')self.log_area.insert(tk.END, message + "\n")self.log_area.see(tk.END)self.log_area.config(state='disabled')self.master.after(0, _update_log)def browse_folder(self):if self.is_running:messagebox.showwarning(self.lang_manager.get_text('title'), self.lang_manager.get_text('task_running'))returnfolder = filedialog.askdirectory()if folder:self.selected_folder.set(folder)def start_renaming_thread(self):if self.is_running:messagebox.showwarning(self.lang_manager.get_text('title'), self.lang_manager.get_text('task_running'))returnroot_dir = self.selected_folder.get()if not root_dir:messagebox.showerror(self.lang_manager.get_text('title'), self.lang_manager.get_text('select_folder_error'))returnif not os.path.isdir(root_dir):messagebox.showerror(self.lang_manager.get_text('title'), self.lang_manager.get_text('invalid_folder_error'))returnif not messagebox.askyesno(self.lang_manager.get_text('title'),self.lang_manager.get_text('confirm_operation').format(folder=os.path.basename(root_dir))):returnself.log_area.config(state='normal')self.log_area.delete('1.0', tk.END)self.log_area.config(state='disabled')self.rename_button.config(state='disabled', text=self.lang_manager.get_text('processing'))self.browse_button.config(state='disabled')self.is_running = Trueself.rename_thread = threading.Thread(target=self.run_rename_task, args=(root_dir,))self.rename_thread.daemon = Trueself.rename_thread.start()def run_rename_task(self, root_dir):try:rename_images_recursively(root_dir, self.log)except Exception as e:self.log(self.lang_manager.get_text('unexpected_error').format(error=str(e)))finally:self.master.after(0, self.on_rename_complete)def on_rename_complete(self):messagebox.showinfo(self.lang_manager.get_text('title'), self.lang_manager.get_text('completed'))self.rename_button.config(state='normal', text=self.lang_manager.get_text('start_rename'))self.browse_button.config(state='normal')self.is_running = False# --- 主程序入口 ---
if __name__ == "__main__":lang_manager = LanguageManager()root = tk.Tk()app = RenamerApp(root)root.mainloop()
# language_manager.py
import os
import json
import localeclass LanguageManager:def __init__(self):self.current_language = Noneself.translations = {}self.locales_dir = os.path.join(os.path.dirname(__file__), 'locales')self.supported_languages = {'en': 'English','zh': '中文','ru': 'Русский','ja': '日本語','de': 'Deutsch','pt': 'Português','fr': 'Français'}# 初始化时自动检测系统语言system_lang = locale.getdefaultlocale()[0]self.default_language = 'en'  # 默认使用英语self.load_language(self.default_language)def load_language(self, lang_code):"""加载指定的语言文件"""if lang_code not in self.supported_languages:lang_code = 'en'  # 默认使用英语try:file_path = os.path.join(self.locales_dir, f'{lang_code}.json')with open(file_path, 'r', encoding='utf-8') as f:self.translations = json.load(f)self.current_language = lang_codereturn Trueexcept Exception as e:print(f'Error loading language file: {e}')return Falsedef get_text(self, key):"""获取翻译文本"""return self.translations.get(key, key)def get_current_language(self):"""获取当前语言代码"""return self.current_languagedef get_supported_languages(self):"""获取支持的语言列表"""return self.supported_languages

使用方法

  1. 克隆或下载项目代码
  2. 运行程序: python rename_images_gui.py
  3. 选择要处理的根文件夹
  4. 点击"开始重命名"按钮
  5. 在日志区域查看处理结果

声明

本项目介绍、博客文章和所有相关内容均由AI生成。


这个工具非常适合摄影师、设计师或需要整理大量图片的用户。它的递归处理和多语言支持使其成为一个非常实用的工具。

相关文章:

AI写程序:图片批量重命名工具 - 自动化整理您的图片库

图片批量重命名工具 - 自动化整理您的图片库 GitHub项目地址: https://github.com/dependon/renameImage 项目介绍 这是一个基于Python开发的图形界面工具&#xff0c;用于批量重命名文件夹中的图片文件。它能够递归处理选定文件夹及其所有子文件夹中的图片&#xff0c;按照…...

git命令自动拉去远程分支到本地

是的&#xff0c;可以通过 Git 命令自动拉取远程分支并在本地创建同名分支。以下是几种方法&#xff1a; 方法 1&#xff1a;直接拉取远程分支并创建同名本地分支 git fetch origin <远程分支名> # 拉取远程分支 git checkout -b <本地分支名> origin/<远程分…...

[创业之路-364]:穿透表象:企业投资的深层逻辑与误区规避

前言&#xff1a; 透过现象看本质 企业一生与人生相似 看企业如同看人 三岁看大&#xff0c;七岁看老 三十年河东&#xff0c;三十年河西 企业也有品行、文化、气质、性格、赚钱、生命周期与赚钱曲线 投资公司的目的是未来赚钱&#xff0c;赚未来赚钱。投资创业中的企业主要看…...

UE5 蓝图里的声音

文章目录 支持的格式设置循环播放在场景中放置音频设置音频的衰减与不衰减在UI动画中播放声音使用蓝图节点播放声音按钮本身就可以播放声音 支持的格式 支持&#xff1a;WAV 不支持&#xff1a;MP3 设置循环播放 双击音频&#xff0c;打开音频设置&#xff0c;勾选Looping …...

Spring Boot 邮件发送配置遇到的坑:解决 JavaMailSenderImpl 未找到的错误

在使用 Spring Boot 开发时&#xff0c;我们经常需要通过邮件发送功能来实现某些业务逻辑。为了方便快速集成&#xff0c;Spring Boot 提供了一个非常好用的 spring-boot-starter-mail 模块&#xff0c;帮助我们轻松发送邮件。但是&#xff0c;在配置过程中可能会遇到一些问题&…...

路由表的最终地址 root 路由跟踪,最终到哪里去

在路由跟踪(如tranceroute或trancert命令)中,最终地址是目标主机或服务器的IP地址或域名所对应的实际网络地址; 路由跟踪的目的是显示数据包从本地主机到目标主机所经过的每一跳路由器或网络节点,而最终地址是数据包要到达的目标设备。 1.路由跟踪的最终地址 目标主机:路…...

Docker面试全攻略(一):镜像打包、容器运行与高频问题解析

引言 在云原生和微服务架构盛行的今天,Docker 已成为后端开发的必备技能。本文从 面试高频考点 出发,系统梳理 Docker 镜像构建、容器运行的核心知识点,助你轻松应对 Docker 相关的技术面试! 一、Docker 镜像构建核心(面试必问) 1. Dockerfile 核心命令与参数 FROM:基…...

方法的重写

目录 1、重写的概念2、方法重写的规则3、重写 VS 重载 1、重写的概念 重写&#xff0c;也称为覆盖&#xff0c;是子类对父类的非构造、非静态、非 final 修饰、非 private 修饰的方法的实现过程的重新编写。重写可以让子类根据需要来实现父类的方法。方法重写是子类与父类的一…...

搭建hadoop集群模式并运行

3.1 Hadoop的运行模式 先去官方看一看Apache Hadoop 3.3.6 – Hadoop: Setting up a Single Node Cluster. 本地模式&#xff1a;数据直接存放在Linux的磁盘上&#xff0c;测试时偶尔用一下 伪分布式&#xff1a;数据存放在HDFS&#xff0c;公司资金不足的时候用 完全分布式&a…...

【学Rust写CAD】39 over_in_in 函数(alpha256补充方法)

源码 // Similar to over_in but includes an additional clip alpha value#[inline]pub fn over_in_in(self,src: Argb, dst: Argb, clip: Alpha) -> Argb {let src_alpha self * clip;let dst_alpha !(src_alpha*src.alpha_t());// we sum src and dst before reducing…...

Visual Studio 2022 UI机器学习训练模块

VS你还是太超标了&#xff0c;现在机器学习都不用写代码了吗&#xff01;&#xff01; 右键项目解决方案&#xff0c;选择机器学习模型...

c# 企业级ADB通信示例

using System; using System.Collections.Generic; using System.Diagnostics; using System.Linq; using System.Text; using System.Threading.Tasks;namespace ADB_Demo {/// <summary>/// ADB管理器&#xff0c;提供与Android设备的通信功能/// </summary>publ…...

linux上todesk无法使用问题

安装 x11 查看是否已安装 X11 dpkg -l | grep xserver-xorg-core 安装 X11&#xff0c;大概需要 17 - 222 MB&#xff08;前者是在服务器上装&#xff0c;后者在自己的 WSL 装&#xff0c;具体视情况而定&#xff09; sudo apt-get install xorg sudo apt-get install xauth s…...

数字IC后端项目典型问题之后端实战项目问题记录

Q1:为了更高效过掉Calibre LVS&#xff0c;我们要求学员在chipfinish阶段需要先做Online LVS检查。该学员在做verifyConnectivity检查发现设计中存在大量的M1 VDD_CORE Un-Connect Pin的violation&#xff0c;具体violation如下图所示。 数字后端培训实战项目六大典型后端实现…...

【机器学习】决策树

一、什么是决策树&#xff1f; 想象一下你玩“二十个问题”游戏的场景&#xff0c;你通过问一系列“是”或“否”的问题来猜测对方心中的物体。决策树的工作方式与此非常相似。它本质上是一个流程图结构&#xff0c;其中&#xff1a; 每个内部节点&#xff08;Internal Node&…...

大模型格式化输出的几种方法

大模型格式化输出的几种方法 在开发一些和LLM相关的应用的时候,如何从大模型的反馈中拿到结构化的输出数据是非常重要的,那么本文就记录几种常用的方法。 OpenAI提供的新方法 在 OpenAI 的 Python 库中,client.beta.chat.completions.parse 是一个用于生成结构化输出的方法…...

250408_解决加载大量数据集速度过慢,耗时过长的问题

250408_解决加载Cifar10等大量数据集速度过慢&#xff0c;耗时过长的问题&#xff08;加载数据时多线程的坑&#xff09; 在做Cifar10图像分类任务时&#xff0c;发现每个step时间过长&#xff0c;且在资源管理器中查看显卡资源调用异常&#xff0c;主要表现为&#xff0c;显卡…...

Linux网络多进程并发服务器和多线程并发服务器

多进程 还是以大小写转换为例子 #include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <pthread.h> #include <sys/socket.h> #include <arpa/inet.h> #include "wrap.h" #include…...

LLMs基础学习(五)模型微调专题(中)

文章目录 LLMs基础学习&#xff08;五&#xff09;模型微调专题&#xff08;中&#xff09;Adapter 类的微调1 背景2 技术原理3 具体细节4 Adapter 类其他方法的微调 Prefix 类的微调1 Prefix Tuning2 Prompt Tuning3 P - tuning4 P - Tuning v25 总结 LoRA 篇a. 什么是 LoRA?…...

不同路由器网段之间的组建

实现PC1到PC7之间的通信 先将基础的ip都配置好 在AR6中将跳板配置好&#xff0c;ip route-static 192.168.5.0 24 64.1.1.2 在AR3中将跳板配置好&#xff0c;ip route-static 192.168.1.0 24 64.1.1.1 如此我们将可以实现通信了 还有第二种&#xff0c;实现PC1到…...

java设计模式-建造者模式

建造者模式(build) 建造者模式的四个角色 1、Product(产品角色)&#xff1a; 一个具体的产品对象。 2、Builder(抽象建造者)&#xff1a; 创建一个Product对象的各个部件指定的 接口或者抽象类。 3、ConcreteBuild(具体建造者)&#xff1a;实现接口&#xff0c;构建和装配各个部…...

【泛函分析】

E&#xff0e;Kreyszig, Introductory functional analysis with applications, Wiley, 1989 1.1 Metric space 满足下面四个性质的映射称为度量&#xff1a;正定、0、对称性和三角不等式 推论&#xff1a;广义的三角不等式 度量可以看成一个映射&#xff0c;验证欧式距离&am…...

【NLP 面经 6】

当上帝赐予你荒野时&#xff0c;就意味着&#xff0c;他要你成为高飞的鹰 —— 25.4.3 一、机器翻译任务&#xff0c;Transformer结构模型改进 在自然语言处理的机器翻译任务中&#xff0c;你采用基于 Transformer 架构的模型。在翻译一些具有丰富文化内涵、习语或隐喻的句子时…...

地质科研智能革命:当大语言模型“扎根”地质现场、大语言模型本地化部署与AI智能体协同创新实践

在地质学迈向“深时数字地球”&#xff08;Deep-time Digital Earth&#xff09;的进程中&#xff0c;传统研究方法正面临海量异构数据&#xff08;地质图件、遥感影像、地震波谱等&#xff09;的解析挑战。大语言模型&#xff08;LLM&#xff09;与AI智能体的本地化部署技术&a…...

蓝桥王国(Dijkstra优先队列)

问题描述 小明是蓝桥王国的王子&#xff0c;今天是他登基之日。 在即将成为国王之前&#xff0c;老国王给他出了道题&#xff0c;他想要考验小明是否有能力管理国家。 题目的内容如下&#xff1a; 蓝桥王国一共有 N 个建筑和 M 条单向道路&#xff0c;每条道路都连接着两个…...

美团mtgsig1.1 分析 mtgsig

声明 本文章中所有内容仅供学习交流使用&#xff0c;不用于其他任何目的&#xff0c;抓包内容、敏感网址、数据接口等均已做脱敏处理&#xff0c;严禁用于商业用途和非法用途&#xff0c;否则由此产生的一切后果均与作者无关&#xff01; 逆向过程 mtgsig有问题的请求3次左右…...

基于STM32、HAL库的CH224Q快充协议芯片简介及驱动程序设计

一、简介&#xff1a; CH224Q是一款USB Type-C快充协议芯片&#xff0c;支持多种快充协议&#xff0c;包括&#xff1a; USB PD 3.0 QC4 QC3.0/2.0 AFC FCP SCP APPLE 2.4A BC1.2 该芯片通过I2C接口与主控MCU通信&#xff0c;可以灵活配置输出电压和获取充电状态信息…...

SvelteKit 最新中文文档教程(18)—— 浅层路由和 Packaging

前言 Svelte&#xff0c;一个语法简洁、入门容易&#xff0c;面向未来的前端框架。 从 Svelte 诞生之初&#xff0c;就备受开发者的喜爱&#xff0c;根据统计&#xff0c;从 2019 年到 2024 年&#xff0c;连续 6 年一直是开发者最感兴趣的前端框架 No.1&#xff1a; Svelte …...

蓝桥杯-数字诗意

问题描述 在诗人的眼中&#xff0c;数字是生活的韵律&#xff0c;也是诗意的表达。 小蓝&#xff0c;当代顶级诗人与数学家&#xff0c;被赋予了"数学诗人"的美誉。他擅长将冰冷的数字与抽象的诗意相融合&#xff0c;并用优雅的文字将数学之美展现于纸上。 某日&a…...

深入探索 Node.js 文件监听机制:从前端工程化到原理剖析

在现代化前端开发中&#xff0c;文件监听&#xff08;File Watching&#xff09;是实现高效开发体验的核心技术之一。从 webpack 的热模块替换到 Vite 的即时刷新&#xff0c;从 CSS 预处理到静态资源打包&#xff0c;背后都依赖于稳健的文件监听机制。本文将深入探讨基于 Node…...

2025 年河北交安安全员考试:巧用行业报告丰富知识储备​

河北交通行业发展迅速&#xff0c;各类行业报告蕴含大量有价值信息。考生可从河北省交通运输行业发展报告、安全专项检查报告等资料入手。在行业发展报告中&#xff0c;了解本省交通建设规模、重点项目规划等内容&#xff0c;这些信息与交安安全员工作紧密相关。比如&#xff0…...

Java9新特性

新的Jshell Java9引入了交互式编程工具jshell&#xff0c;可用于快速测试和学习Java。 特性 该工具可用于快速测试代码片段&#xff0c;无需创建java文件。支持自动补全和历史命令支持保存和加载会话 不可变集合工厂方法 Java9新增了List.of()、Set.of()、Map.of()和Map.o…...

CS内网渗透 - 如何通过冰蝎 Webshell 上线 Weblogic 服务器到 Cobalt Strike 并绕过杀软检测(360、火绒)?

目录 1. 冰蝎连接上 Weblogic 服务器如何上线到 Cobalt Strike 2. 服务器安装杀毒工具如何绕过杀软上线到 Cobalt Strike 2.1 杀软对 Webshell 命令执行的检测及绕过 2.2 杀软对 Cobalt Strike 上线木马的检测及绕过 2.3 杀软对这两方面的限制及综合绕过 3. 如何生成免杀…...

Linux开发过程中常用命令整理

docker ps -a查看所有(包括已经停止的) systemctl 功能&#xff1a;控制系统服务的启动关闭等 语法&#xff1a;systemctl start | stop | restart | disable | enable | status 服务名​ start&#xff0c;启动stop&#xff0c;停止status&#xff0c;查看状态disable&#xf…...

触想工业一体机助力打造安全智能的数字化配电系统

一、项目开发背景 现代社会运行依赖稳定的电力供应&#xff0c;尤其在工业生产、城市基础设施、商业建筑等关键领域&#xff0c;即便是0.1秒的电力中断也可能导致严重后果。同时&#xff0c;随着全球用电负荷加剧及能源结构转型&#xff0c;对电力系统的运维效率、能源利用和数…...

从代码学习深度学习 - 序列到序列学习 GRU编解码器 PyTorch 版

文章目录 前言一、数据加载与预处理1.1 读取数据1.2 预处理数据1.3 词元化1.4 词频统计1.5 构建词汇表1.6 截断与填充1.7 转换为张量1.8 创建数据迭代器1.9 整合数据加载二、训练辅助工具2.1 时间记录器2.2 累加器2.3 准确率计算2.4 GPU 上的准确率评估2.5 GPU 设备选择2.6 梯度…...

华为AI-agent新作:使用自然语言生成工作流

论文标题 WorkTeam: Constructing Workflows from Natural Language with Multi-Agents 论文地址 https://arxiv.org/pdf/2503.22473 作者背景 华为&#xff0c;北京大学 动机 当下AI-agent产品百花齐放&#xff0c;尽管有ReAct、MCP等框架帮助大模型调用工具&#xff0…...

基于PyTorch 实现一个基于 Transformer 架构的字符级语言模型

这篇教程将带你一步步在 JupyterLab 中实现一个简单的语言模型。我们将从零开始&#xff0c;使用 PyTorch 实现一个基于 Transformer 架构的字符级语言模型。尽管在实际应用中&#xff0c;大多数人更倾向于使用 Hugging Face 的预训练模型&#xff0c;但本文的目的是让你了解语…...

苹果签名的工具有哪些

嗯&#xff0c;用户问的是关于苹果企业签名的工具有哪些。首先&#xff0c;我需要确认用户的需求。苹果企业签名通常指的是使用苹果的企业开发者账号&#xff08;Apple Developer Enterprise Program&#xff09;来对应用进行签名&#xff0c;这样应用可以不通过App Store直接分…...

解决.net接口防暴力调用问题

在 .NET 中&#xff0c;为解决接口防暴力调用问题&#xff0c;可通过限制请求频率实现。下面给出几种不同实现方式。 基于内存的简单速率限制 此方法适用于单服务器环境&#xff0c;它借助内存字典来记录每个客户端的请求次数和时间。 MemoryRateLimitMiddleware.cs using …...

java设计模式-桥接模式

桥接模式(Bridge) 基本介绍 1、桥接模式(Bridge)是指&#xff1a;将实现与抽象放在两个不同的类层次中&#xff0c;是两个层次可以独立改变。 2、是一种结构设计模 3、Bridge模式给予类的最小单元设计原则&#xff0c;通过使用封装&#xff0c;聚合及继承等行为让不同的类承担不…...

cdw2: TypeScript

一、javascript的问题 二、初识typescript https://mp.weixin.qq.com/s/wnL1l-ERjTDykWM76l4Ajw 三、类型 二进制&#xff1a;ob开头&#xff0c;八进制&#xff1a;0o开头&#xff0c;十六进制&#xff1a;0x开头 开发中不这样写 这样写 匿名函数的参数最好不要…...

Linux驱动开发:SPI驱动开发原理

前言 本文章是根据韦东山老师的教学视频整理的学习笔记https://video.100ask.net/page/1712503 SPI 通信协议采用同步全双工传输机制&#xff0c;拓扑架构支持一主多从连接模式&#xff0c;这种模式在实际应用场景中颇为高效。其有效传输距离大致为 10m &#xff0c;传输速率…...

Java 通过 JNI 调用 C++ 动态库的完整流程

介绍使用 JNI 调用 C 编写的动态链接库的全过程。 示例环境 项目说明JDK8C 编译器Visual Studio 2019Java 开发工具IntelliJ IDEA 2021.3操作系统Windows 10 Java 项目结构概览 编写 Java 类 在 org.jni.nativejni 包下创建类 HelloWorldJni.java&#xff1a; package org…...

oracle 11g密码长度和复杂度查看与设置

一 查看当前的密码复杂度设置 SELECT * FROM dba_profiles WHERE resource_name PASSWORD_VERIFY_FUNCTION; LIMIT表示分配给该 PROFILE 的密码验证函数名称。如果为 NULL&#xff0c;表示未设置密码验证函数。 #查看是否有相关密码验证函数 select object_name from dba…...

1021 Deepest Root

1021 Deepest Root 分数 25 全屏浏览 切换布局 作者 CHEN, Yue 单位 浙江大学 A graph which is connected and acyclic can be considered a tree. The height of the tree depends on the selected root. Now you are supposed to find the root that results in a highest…...

1. 三带一

所谓“三带一”牌型&#xff0c;即四张手牌中&#xff0c;有三张牌一样&#xff0c;另外一张不与其他牌相同&#xff0c;换种说法&#xff0c;四张手牌经过重新排列后&#xff0c;可以组成 AAABAAAB 型。 输入格式 第一行输入一个整数 TT &#xff0c;代表斗地主的轮数。 接…...

pytorch计算图Computation_graph是什么

文章目录 一、AI系统中的计算图&#xff08;宏观&#xff09;二、动态计算图&#xff08;微观&#xff09;2.1 张量计算图2.2 计算图的定义2.3 节点类型2.4 计算图的动态性2.5 计算图的正向传播是立即执行的2.6 计算图在反向传播后立即销毁2.7 计算图中的Function2.8 计算图与反…...

HTML5元素

HTML5的<section>元素和<article>元素 <section>元素定义文档中的一部分&#xff0c;着重于对页面内容进行分块或者分段&#xff0c;通常可以分为引言、内容和联系人信息等几个部分。 <section><h1>WWF</h1><p>WWF 是世界自然基金…...

单reactor实战

前言&#xff1a;reactor作为一种高性能的范式&#xff0c;值得我们学习 本次目标 实现一个基于的reactor 具备echo功能的服务器 核心组件 Reactor本身是靠一个事件驱动的框架,无疑引出一个类似于moduo的"EventLoop "以及boost.asio中的context而言&#xff0c;不断…...