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

Jimeng LoRA代码实例:为LoRA测试台添加生成图自动归档与标签系统

Jimeng LoRA代码实例为LoRA测试台添加生成图自动归档与标签系统1. 项目概述今天给大家分享一个实用的技术方案如何为Jimeng LoRA测试台添加生成图片的自动归档和标签系统。这个功能特别适合需要频繁测试不同LoRA版本效果的研究人员和开发者。Jimeng LoRA测试台本身已经是个很不错的工具它基于Z-Image-Turbo底座支持动态切换不同训练阶段的LoRA版本测试效率很高。但之前有个小问题生成的图片都堆在一个文件夹里时间一长就分不清哪张图是哪个版本生成的了。我们这次要做的改进很简单但很实用自动按日期创建文件夹归档图片为每张图片添加包含版本信息的文件名在图片元数据中嵌入完整的生成参数添加简单的搜索和筛选功能这样以后找图、对比效果就方便多了。下面我带大家一步步实现这个功能。2. 环境准备与代码结构2.1 所需依赖首先确保你的环境中安装了这些Python包# requirements.txt 新增依赖 pillow10.0.0 # 用于处理图片元数据 streamlit1.28.0 # Web界面框架 torch2.0.0 # 深度学习框架 transformers4.30.0 # 模型推理 accelerate0.20.0 # 推理加速2.2 项目结构jimeng_lora_tester/ ├── app.py # 主程序文件 ├── lora_models/ # LoRA模型存放目录 ├── outputs/ # 输出目录按日期自动创建子文件夹 ├── utils/ │ ├── image_utils.py # 图片处理工具函数 │ └── metadata.py # 元数据处理模块 └── config.py # 配置文件3. 自动归档系统实现3.1 创建日期文件夹我们先来实现按日期自动创建文件夹的功能# utils/image_utils.py import os from datetime import datetime def create_date_folder(base_output_dir): 创建按日期命名的文件夹 today datetime.now().strftime(%Y-%m-%d) date_dir os.path.join(base_output_dir, today) if not os.path.exists(date_dir): os.makedirs(date_dir) print(f创建日期文件夹: {date_dir}) return date_dir3.2 生成带标签的文件名接下来为每张图片生成包含版本信息的文件名def generate_image_filename(lora_name, prompt, output_dir): 生成包含版本信息的文件名 # 简化LoRA名称去掉特殊字符 clean_lora_name lora_name.replace(.safetensors, ).replace(_, -) # 截取提示词前几个词作为描述 words prompt.split()[:3] short_desc _.join(words).lower() # 添加时间戳避免重名 timestamp datetime.now().strftime(%H%M%S) filename f{clean_lora_name}_{short_desc}_{timestamp}.png full_path os.path.join(output_dir, filename) return full_path, filename4. 元数据标签系统4.1 写入生成参数到图片元数据为了让每张图片都包含完整的生成信息我们在元数据中写入所有相关参数# utils/metadata.py from PIL import Image, PngImagePlugin import json def add_metadata_to_image(image, metadata_dict): 将生成参数写入图片元数据 # 转换为PNG格式的元数据 png_info PngImagePlugin.PngInfo() for key, value in metadata_dict.items(): if isinstance(value, (dict, list)): # 复杂对象转为JSON字符串 value json.dumps(value, ensure_asciiFalse) else: value str(value) png_info.add_text(key, value) return png_info def save_image_with_metadata(image_path, image, metadata): 保存图片并添加元数据 png_info add_metadata_to_image(image, metadata) image.save(image_path, PNG, pnginfopng_info)4.2 完整的元数据信息我们记录这些重要的生成信息def create_metadata_dict(lora_name, prompt, negative_prompt, seed, steps, cfg_scale, sampler_name): 创建完整的元数据字典 return { lora_model: lora_name, prompt: prompt, negative_prompt: negative_prompt, seed: seed, steps: steps, cfg_scale: cfg_scale, sampler: sampler_name, generation_date: datetime.now().isoformat(), tool: Jimeng LoRA Tester with Auto-Archiving }5. 集成到主程序5.1 修改生成函数现在把归档功能集成到主要的图片生成函数中# 在主程序的生成函数中添加这些代码 def generate_image_with_archiving(lora_name, prompt, negative_prompt, seed, steps, cfg_scale, sampler): # ... 原有的生成逻辑 ... # 生成图片 image generate_image(prompt, negative_prompt, lora_name, seed, steps, cfg_scale, sampler) # 创建日期文件夹 output_dir create_date_folder(outputs) # 生成带标签的文件名 image_path, filename generate_image_filename(lora_name, prompt, output_dir) # 创建元数据 metadata create_metadata_dict(lora_name, prompt, negative_prompt, seed, steps, cfg_scale, sampler) # 保存带元数据的图片 save_image_with_metadata(image_path, image, metadata) return image, image_path, metadata5.2 更新Streamlit界面在Web界面中显示归档信息# 在Streamlit界面中添加归档状态显示 import streamlit as st def show_archiving_status(): 显示归档状态信息 today datetime.now().strftime(%Y-%m-%d) output_dir os.path.join(outputs, today) if os.path.exists(output_dir): image_count len([f for f in os.listdir(output_dir) if f.endswith(.png)]) st.sidebar.info(f今日已生成: {image_count} 张图片) st.sidebar.write(f保存位置: {output_dir})6. 图片浏览与搜索功能6.1 简单的图片浏览器添加一个简单的图片浏览界面def image_browser(): 图片浏览界面 st.header( 生成图片浏览器) # 选择日期文件夹 date_folders sorted([f for f in os.listdir(outputs) if os.path.isdir(os.path.join(outputs, f))], reverseTrue) if date_folders: selected_date st.selectbox(选择日期, date_folders) date_dir os.path.join(outputs, selected_date) # 显示该日期的所有图片 image_files [f for f in os.listdir(date_dir) if f.endswith(.png)] if image_files: selected_image st.selectbox(选择图片, image_files) image_path os.path.join(date_dir, selected_image) # 显示图片和元数据 col1, col2 st.columns(2) with col1: st.image(image_path, captionselected_image, use_column_widthTrue) with col2: # 读取并显示元数据 metadata read_image_metadata(image_path) if metadata: st.write(生成参数:) for key, value in metadata.items(): st.write(f**{key}**: {value})6.2 元数据读取函数def read_image_metadata(image_path): 读取图片中的元数据 try: image Image.open(image_path) metadata {} for key in image.text.keys(): value image.text[key] # 尝试解析JSON格式的值 try: metadata[key] json.loads(value) except: metadata[key] value return metadata except Exception as e: print(f读取元数据失败: {e}) return None7. 完整代码示例这里是一个整合后的完整示例# app.py 主程序文件 import streamlit as st import os from datetime import datetime from PIL import Image import json from utils.image_utils import create_date_folder, generate_image_filename from utils.metadata import create_metadata_dict, save_image_with_metadata # 初始化界面 st.set_page_config(page_titleJimeng LoRA Tester with Archiving, layoutwide) st.title(Jimeng LoRA 测试台 - 带自动归档系统) # 显示归档状态 show_archiving_status() # 原有的LoRA选择和生成界面 # ... [原有的界面代码] ... # 生成按钮 if st.button(生成图片): with st.spinner(生成中...): try: # 调用带归档的生成函数 image, image_path, metadata generate_image_with_archiving( selected_lora, prompt, negative_prompt, seed, steps, cfg_scale, sampler ) # 显示结果 st.image(image, captionf生成结果: {os.path.basename(image_path)}) # 显示元数据摘要 with st.expander(查看生成参数): st.json(metadata) st.success(f图片已保存到: {image_path}) except Exception as e: st.error(f生成失败: {str(e)}) # 图片浏览标签页 tab1, tab2 st.tabs([生成界面, 图片浏览]) with tab2: image_browser()8. 使用效果与建议8.1 实际使用效果添加自动归档系统后你会发现整理效率大幅提升不再需要手动整理生成的图片系统自动按日期分类查找更方便通过文件名就能知道是哪版LoRA生成的什么内容参数追溯任何时候都能查看某张图片的完整生成参数对比分析可以轻松对比不同版本LoRA在同参数下的效果差异8.2 使用建议根据实际使用经验我给大家几个建议定期清理虽然自动归档很好用但建议定期清理旧的输出文件备份重要结果特别好的生成结果建议单独备份使用有意义的提示词好的提示词能让文件名更有描述性定期检查存储空间大量生成图片可能会占用不少空间8.3 进一步优化方向如果还需要更强大的功能可以考虑添加数据库支持用SQLite记录所有生成记录支持复杂查询添加评分系统为生成的图片打分方便筛选最佳结果批量导出功能支持按条件批量导出图片和参数云端同步将生成结果自动同步到云存储9. 总结通过为Jimeng LoRA测试台添加自动归档和标签系统我们大大提升了使用体验和工作效率。这个方案有这些优点实用价值自动整理生成的图片节省大量手动整理时间完整的元数据记录方便追溯和复现简单的浏览和搜索功能查找图片更便捷技术亮点轻量级实现不增加太多复杂依赖保持原有性能不影响生成速度良好的扩展性可以继续添加新功能易用性开箱即用无需复杂配置界面直观操作简单文档完整容易理解和使用这个改进虽然不大但对实际工作流程的优化效果很明显。特别适合需要频繁测试和对比不同LoRA版本的用户。获取更多AI镜像想探索更多AI镜像和应用场景访问 CSDN星图镜像广场提供丰富的预置镜像覆盖大模型推理、图像生成、视频生成、模型微调等多个领域支持一键部署。

相关文章:

Jimeng LoRA代码实例:为LoRA测试台添加生成图自动归档与标签系统

Jimeng LoRA代码实例:为LoRA测试台添加生成图自动归档与标签系统 1. 项目概述 今天给大家分享一个实用的技术方案:如何为Jimeng LoRA测试台添加生成图片的自动归档和标签系统。这个功能特别适合需要频繁测试不同LoRA版本效果的研究人员和开发者。 Jim…...

OFA-VE多模态推理实操手册:基于OFA-Large的语义对齐分析全流程

OFA-VE多模态推理实操手册:基于OFA-Large的语义对齐分析全流程 1. 引言:什么是视觉蕴含分析? 你有没有遇到过这样的情况:看到一张图片,然后有人用文字描述它,但你不太确定这个描述是否准确?或…...

3步打造永不丢失的聊天记录:RevokeMsgPatcher革新性防撤回技术全解析

3步打造永不丢失的聊天记录:RevokeMsgPatcher革新性防撤回技术全解析 【免费下载链接】RevokeMsgPatcher :trollface: A hex editor for WeChat/QQ/TIM - PC版微信/QQ/TIM防撤回补丁(我已经看到了,撤回也没用了) 项目地址: http…...

告别繁琐计算!MAA智能公招助手:一键解锁明日方舟高效标签组合方案

告别繁琐计算!MAA智能公招助手:一键解锁明日方舟高效标签组合方案 【免费下载链接】MaaAssistantArknights 一款明日方舟游戏小助手 项目地址: https://gitcode.com/GitHub_Trending/ma/MaaAssistantArknights MAA智能公招助手是明日方舟游戏小助…...

Llama-3.2V-11B-cot参数详解:stream=True + max_new_tokens=512最佳实践

Llama-3.2V-11B-cot参数详解:streamTrue max_new_tokens512最佳实践 1. 项目概述 Llama-3.2V-11B-cot是基于Meta Llama-3.2V-11B-cot多模态大模型开发的高性能视觉推理工具,专为双卡RTX 4090环境深度优化。该工具通过以下创新设计显著降低了多模态大模…...

小说作者必备:次元画室快速构建角色设定,灵感秒变草图

小说作者必备:次元画室快速构建角色设定,灵感秒变草图 你是否经常遇到这样的困境:脑海中浮现出一个鲜活的角色形象,却苦于无法用文字准确描述?或者写好了人物设定,却找不到合适的画师将其可视化&#xff1…...

别再用multiprocessing了!:用subinterpreter + shared_memory构建单进程10万QPS无锁API网关(附压测对比图)

第一章:Python 无锁 GIL 环境下的并发模型实战案例Python 的全局解释器锁(GIL)长期被视为 CPU 密集型并发的瓶颈,但现代 Python 生态已通过多进程、协程、外部 C 扩展及子解释器等机制,在特定场景下实现真正意义上的“…...

Kook Zimage真实幻想Turbo部署教程:免conda环境纯pip安装方案

Kook Zimage真实幻想Turbo部署教程:免conda环境纯pip安装方案 1. 项目简介 Kook Zimage真实幻想Turbo是一款专为个人GPU设计的轻量化幻想风格文生图系统。它基于Z-Image-Turbo官方极速文生图底座,通过特殊技术融合了专属的幻想风格模型权重&#xff0c…...

影墨·今颜模型在网络安全教学中的应用:生成网络拓扑与攻击场景示意图

影墨今颜模型在网络安全教学中的应用:生成网络拓扑与攻击场景示意图 网络安全教学一直有个难题:很多概念太抽象了。你跟学生讲“中间人攻击”,讲“DDoS流量”,或者讲“防火墙策略”,他们脑子里可能只有一堆文字&#…...

终极指南:如何快速部署Ip2region离线IP定位系统

终极指南:如何快速部署Ip2region离线IP定位系统 【免费下载链接】ip2region Ip2region (2.0 - xdb) 是一个离线IP地址管理与定位框架,能够支持数十亿级别的数据段,并实现十微秒级的搜索性能。它为多种编程语言提供了xdb引擎实现。 项目地址…...

FLUX.1-dev-fp8-dit开发:PID控制算法可视化工具

FLUX.1-dev-fp8-dit开发:PID控制算法可视化工具 做自动化控制的朋友,估计没少跟PID算法打交道。调参调到头秃,对着波形图猜哪个参数不对,这种经历大家都有。传统的调试方法,要么在真实设备上反复试错,成本…...

Ip2region终极指南:如何快速部署高性能离线IP定位系统

Ip2region终极指南:如何快速部署高性能离线IP定位系统 【免费下载链接】ip2region Ip2region (2.0 - xdb) 是一个离线IP地址管理与定位框架,能够支持数十亿级别的数据段,并实现十微秒级的搜索性能。它为多种编程语言提供了xdb引擎实现。 项…...

Youtu-Parsing工业文档解析:设备说明书表格+示意图+技术参数提取

Youtu-Parsing工业文档解析:设备说明书表格示意图技术参数提取 1. 引言:当工业文档遇上智能解析 想象一下这个场景:你是一家设备制造公司的技术工程师,手头有一份50页的设备说明书PDF,里面密密麻麻全是技术参数表格、…...

PvZ Toolkit:植物大战僵尸全能修改工具全面解析

PvZ Toolkit:植物大战僵尸全能修改工具全面解析 【免费下载链接】pvztoolkit 植物大战僵尸 PC 版综合修改器 项目地址: https://gitcode.com/gh_mirrors/pv/pvztoolkit PvZ Toolkit 是一款专为《植物大战僵尸》PC版设计的开源修改工具,支持从Wind…...

别再为电赛E题发愁了!用OpenMV+舵机云台搞定运动目标追踪的保姆级避坑指南

OpenMV舵机云台运动目标追踪实战:从硬件搭建到代码调试的全流程避坑指南 刚拿到电赛E题任务书时,看着"运动目标控制与自动追踪系统"这个标题,我和队友面面相觑——既要处理图像识别,又要协调舵机运动,这对毫…...

AudioLDM-S性能优化:MySQL数据库存储百万级音效元数据

AudioLDM-S性能优化:MySQL数据库存储百万级音效元数据 1. 引言 想象一下,你正在运营一个大型音效库平台,每天要处理数十万次的音效搜索请求。用户输入"雨声"或"城市夜晚",系统需要在毫秒内从百万级别的音效…...

MongoDB C Driver事务处理:ACID保证与分布式事务最佳实践

MongoDB C# Driver事务处理:ACID保证与分布式事务最佳实践 【免费下载链接】mongo-csharp-driver The Official C# .NET Driver for MongoDB 项目地址: https://gitcode.com/gh_mirrors/mo/mongo-csharp-driver MongoDB C# Driver是MongoDB官方提供的.NET驱动…...

Kotaemon在教育培训中的应用:如何构建可信赖的学科答疑助手?

Kotaemon在教育培训中的应用:如何构建可信赖的学科答疑助手? 1. 教育场景中的AI答疑痛点 想象这样一个场景:晚自习教室里,一个学生正为生物作业发愁。他在手机上输入:"光合作用的暗反应发生在叶绿体的哪个部位&…...

Qwen3-Embedding-0.6B新手指南:从零开始玩转文本嵌入

Qwen3-Embedding-0.6B新手指南:从零开始玩转文本嵌入 1. 什么是文本嵌入?为什么你需要它? 想象一下,你有一个装满各种文档、网页和笔记的文件夹。当你想找“如何用Python做数据分析”的资料时,你只能靠记忆或者手动翻…...

Nomic-Embed-Text-V2-MoE部署排错指南:解决403 Forbidden等常见API访问错误

Nomic-Embed-Text-V2-MoE部署排错指南:解决403 Forbidden等常见API访问错误 部署一个新的模型服务,就像给家里添置一台新电器,插上电、打开开关,本以为就能顺利运转,结果却发现指示灯不亮,或者干脆跳闸了。…...

CogVideoX-2b效果精评:镜头语言与叙事节奏的AI表现力

CogVideoX-2b效果精评:镜头语言与叙事节奏的AI表现力 1. 开篇:当AI成为导演 想象一下,你只需要输入一段文字描述,就能得到一个完整的短视频。这不是科幻电影,而是CogVideoX-2b带给我们的现实体验。这个基于智谱AI开源…...

LFM2.5-1.2B-Thinking-GGUF实战教程:用三句话讲清GGUF——模型本身即教程

LFM2.5-1.2B-Thinking-GGUF实战教程:用三句话讲清GGUF——模型本身即教程 1. 认识LFM2.5-1.2B-Thinking-GGUF LFM2.5-1.2B-Thinking-GGUF是Liquid AI推出的一款轻量级文本生成模型,专为低资源环境优化设计。这个模型最大的特点是内置了GGUF格式的模型文…...

3大核心模块构建戴森球计划模块化生产体系:从混乱到有序的进阶指南

3大核心模块构建戴森球计划模块化生产体系:从混乱到有序的进阶指南 【免费下载链接】FactoryBluePrints 游戏戴森球计划的**工厂**蓝图仓库 项目地址: https://gitcode.com/GitHub_Trending/fa/FactoryBluePrints 概念解析:模块化生产的本质与价值…...

一键生成黑苹果EFI配置:OpCore Simplify新手完全指南

一键生成黑苹果EFI配置:OpCore Simplify新手完全指南 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify OpCore Simplify是一款革命性的黑苹果…...

Qwen2.5-7B离线推理实战:无需GPU,CPU版本快速部署指南

Qwen2.5-7B离线推理实战:无需GPU,CPU版本快速部署指南 1. 引言 在当今AI技术快速发展的背景下,大型语言模型的应用越来越广泛。然而,许多开发者和企业在实际部署时面临GPU资源不足或成本过高的问题。本文将介绍如何在普通CPU环境…...

使用Pi0具身智能开发教育机器人的完整指南

使用Pi0具身智能开发教育机器人的完整指南 1. 引言 教育领域正在经历一场智能化变革,传统的教学模式已经难以满足个性化学习的需求。想象一下,一个能够理解学生情绪、提供个性化辅导、并且24小时在线的教育助手——这就是教育机器人带来的可能性。 Pi…...

LangChain4j的AiServices到底怎么用?一个注解让SpringBoot服务秒变AI智能体

LangChain4j的AiServices深度实践:用声明式编程重构SpringBoot智能服务 在Java生态中集成大语言模型(LLM)时,开发者常常面临一个架构难题:如何在保持代码整洁的同时,优雅地组织AI能力?LangChain…...

百川2-13B量化版性能实测:OpenClaw长任务下的Token消耗与稳定性

百川2-13B量化版性能实测:OpenClaw长任务下的Token消耗与稳定性 1. 测试背景与动机 上周在尝试用OpenClaw自动化处理一个包含2000多份PDF的文献库时,遇到了令人头疼的Token消耗问题。原本计划让AI助手完成"读取PDF标题-提取关键词-分类归档"…...

打卡信奥刷题(3025)用C++实现信奥题 P6393 隔离的日子

P6393 隔离的日子 题目背景 (背景改编自 百度贴吧/南北组备用吧/呆萌南北日常/F9023,作者 落墨成白) 数据已修复。 一天又一天,每到深夜房间里又只余下手机屏幕的亮光,洛天依总会有一种与世界割离的失落感。   闷…...

Python AOT编译安全黄金标准:基于LLVM-MCA+SGXv2+eBPF验证链的5步合规上线清单

第一章:Python AOT编译安全黄金标准的演进与定义Python 传统上依赖解释执行与字节码(.pyc)机制,其动态性在提升开发效率的同时,也为运行时注入、字节码篡改和调试器劫持等攻击面埋下隐患。AOT(Ahead-of-Tim…...