news 2026/2/16 12:52:05

GPEN输出文件命名规则自定义:脚本修改详细教程

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
GPEN输出文件命名规则自定义:脚本修改详细教程

GPEN输出文件命名规则自定义:脚本修改详细教程

GPEN人像修复增强模型镜像

本镜像基于GPEN人像修复增强模型构建,预装了完整的深度学习开发环境,集成了推理及评估所需的所有依赖,开箱即用。

1. 镜像环境说明

组件版本
核心框架PyTorch 2.5.0
CUDA 版本12.4
Python 版本3.11
推理代码位置/root/GPEN

主要依赖库:

  • facexlib: 用于人脸检测与对齐
  • basicsr: 基础超分框架支持
  • opencv-python,numpy<2.0,datasets==2.21.0,pyarrow==12.0.1
  • sortedcontainers,addict,yapf

2. 快速上手

2.1 激活环境

conda activate torch25

2.2 模型推理 (Inference)

进入代码目录并使用预置脚本进行推理测试:

cd /root/GPEN

使用下面命令进行推理测试,可以通过命令行参数灵活指定输入图片。

# 场景 1:运行默认测试图 # 输出将保存为: output_Solvay_conference_1927.png python inference_gpen.py # 场景 2:修复自定义图片 # 输出将保存为: output_my_photo.jpg python inference_gpen.py --input ./my_photo.jpg # 场景 3:直接指定输出文件名 # 输出将保存为: custom_name.png python inference_gpen.py -i test.jpg -o custom_name.png

推理结果将自动保存在项目根目录下,测试结果如下:


3. 默认输出命名机制分析

3.1 命名逻辑解析

当你运行inference_gpen.py脚本时,如果没有通过-o参数显式指定输出文件名,系统会根据输入文件的名称自动生成一个默认的输出名。其规则如下:

  • 输入文件名为xxx.jpgxxx.png,则输出文件名为output_xxx.png
  • 若未提供输入文件(使用默认测试图),则输出为output_Solvay_conference_1927.png

这个逻辑隐藏在脚本内部的get_save_path()或类似函数中,通常位于主函数调用前的数据处理部分。

3.2 查看原始命名代码

我们可以通过查看/root/GPEN/inference_gpen.py文件中的关键段落来确认这一行为:

# 示例代码片段(非原生,模拟实际逻辑) if args.input is None: input_path = 'test_images/Solvay_conference_1927.jpg' else: input_path = args.input # 提取文件名(不含扩展名) base_name = os.path.splitext(os.path.basename(input_path))[0] # 构造输出路径 if args.output is None: output_path = f'output_{base_name}.png' else: output_path = args.output

可以看到,默认命名是通过拼接"output_" + 原始文件名(无后缀) + .png"实现的。


4. 自定义输出命名规则的方法

虽然可以通过-o参数临时指定输出名,但如果你需要批量处理多张图像或希望统一命名风格(如按时间戳、用户ID、场景分类等),手动加参数显然不现实。因此,我们需要修改脚本本身来实现持久化、个性化的命名策略。

4.1 修改目标定位

打开推理脚本:

nano /root/GPEN/inference_gpen.py

搜索以下关键字之一:

  • output_path
  • save_path
  • args.output
  • f'output_'

找到负责生成默认输出路径的那一段代码。

4.2 添加时间戳命名规则

假设你希望每次生成的文件都带有时间信息,便于归档和区分,可以这样改写:

import datetime # 在文件顶部导入 datetime 模块 # 找到原输出路径生成逻辑,替换为: if args.output is None: base_name = os.path.splitext(os.path.basename(input_path))[0] timestamp = datetime.datetime.now().strftime("%Y%m%d_%H%M%S") output_path = f'{base_name}_enhanced_{timestamp}.png' else: output_path = args.output

效果示例:

  • 原图portrait.jpg→ 输出portrait_enhanced_20250405_142310.png

这种方式特别适合做自动化处理或实验记录。

4.3 按用户/场景分类命名

如果你为人像增强服务不同客户或用途(如证件照、社交头像、老照片修复),可加入前缀标识:

# 定义用途类型(可通过新增参数传入,也可固定设置) scene_prefix = "idphoto" # 可选: social, oldphoto, beauty 等 if args.output is None: base_name = os.path.splitext(os.path.basename(input_path))[0] output_path = f'{scene_prefix}_{base_name}_restored.png' else: output_path = args.output

输出示例:

  • idphoto_zhangsan_restored.png
  • oldphoto_childhood_restored.png

4.4 使用递增编号避免重名

对于无人值守的批处理任务,建议使用数字编号防止覆盖:

import glob def get_next_filename(base_name, ext=".png"): prefix = f"{base_name}_v" existing = glob.glob(f"{prefix}*{ext}") if not existing: return f"{prefix}01{ext}" numbers = [] for file in existing: try: num = int(file.split('_v')[-1].split('.')[0]) numbers.append(num) except: continue next_num = max(numbers) + 1 if numbers else 1 return f"{prefix}{next_num:02d}{ext}" # 使用方式 if args.output is None: base_name = os.path.splitext(os.path.basename(input_path))[0] output_path = get_next_filename("face", ".png") # face_v01.png, face_v02.png... else: output_path = args.output

5. 进阶技巧:从命令行传入自定义命名模板

为了兼顾灵活性与易用性,我们可以扩展脚本功能,允许用户通过新参数控制命名模式。

5.1 新增命令行参数

修改argparse部分,添加--name-template参数:

parser.add_argument('--name-template', type=str, default=None, help='Custom naming template. Use {name}, {time}, {suffix}. Example: "{name}_fixed_{time}"')

5.2 实现动态命名模板解析

在输出路径生成处加入模板替换逻辑:

import datetime if args.output is None: name = os.path.splitext(os.path.basename(input_path))[0] time_str = datetime.datetime.now().strftime("%H%M") if args.name_template: # 支持占位符替换 output_name = args.name_template.format( name=name, time=time_str, suffix="enhanced" ) + ".png" else: output_name = f"output_{name}.png" output_path = output_name else: output_path = args.output

5.3 使用示例

# 使用自定义模板 python inference_gpen.py -i myface.jpg --name-template "{name}_gpen_{time}" # 输出:myface_gpen_1423.png

这使得同一个脚本能适应多种业务场景,无需反复修改源码。


6. 批量处理中的命名实践建议

当你要对一批图片进行修复时,合理的命名规则尤为重要。以下是几种推荐做法:

6.1 统一前缀 + 序号

适用于归档管理:

# 批量脚本片段 for idx, img_path in enumerate(image_list): base = os.path.basename(img_path).rsplit('.', 1)[0] output = f"batch_{idx+1:03d}_{base}.png"

6.2 保留原始目录结构命名

若输入来自多个子文件夹,可用路径信息编码:

# 如输入为 data/teamA/001.jpg rel_path = os.path.relpath(img_path, start_dir) # teamA/001.jpg safe_name = rel_path.replace('/', '_') output = f"restored_{safe_name}.png" # restored_teamA_001.png

6.3 加入质量等级标识

如果对不同分辨率或强度的修复结果分别保存,可在名字中标注:

resolution_tag = "512" # 或 1024 output = f"{base}_gpen_{resolution_tag}p.png"

7. 总结

7.1 核心要点回顾

  • GPEN 默认输出格式为output_<filename>.png,由脚本内硬编码逻辑决定。
  • 可通过-o参数临时指定输出名,适合单次调用。
  • 若要实现永久性、个性化命名规则,需修改inference_gpen.py中的输出路径生成逻辑。
  • 推荐方法包括:添加时间戳、分类前缀、递增编号、支持模板变量等。
  • 结合argparse扩展参数,可让脚本更灵活地服务于不同应用场景。

7.2 实践建议

  • 修改前先备份原脚本:cp inference_gpen.py inference_gpen.py.bak
  • 测试新命名逻辑时,先用小图试跑,确保不出错
  • 若用于生产环境,建议封装成独立配置文件或.yaml控制命名策略
  • 注意文件路径权限问题,确保输出目录可写

掌握输出命名的自定义方法,不仅能提升工作效率,还能让你的AI处理流程更加专业、有序。无论是个人使用还是团队协作,清晰的命名规范都是高质量项目的重要标志。


获取更多AI镜像

想探索更多AI镜像和应用场景?访问 CSDN星图镜像广场,提供丰富的预置镜像,覆盖大模型推理、图像生成、视频生成、模型微调等多个领域,支持一键部署。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/16 9:24:56

Qwen3-Embedding-0.6B免配置部署:镜像一键启动SGlang服务

Qwen3-Embedding-0.6B免配置部署&#xff1a;镜像一键启动SGlang服务 1. Qwen3-Embedding-0.6B 模型简介 你有没有遇到过这样的问题&#xff1a;想做个智能搜索系统&#xff0c;但文本匹配效果总是差强人意&#xff1f;或者在做多语言内容推荐时&#xff0c;发现传统方法根本…

作者头像 李华
网站建设 2026/2/12 15:05:54

Qwen3-0.6B医疗问答系统:隐私保护部署教程

Qwen3-0.6B医疗问答系统&#xff1a;隐私保护部署教程 1. 认识Qwen3-0.6B&#xff1a;轻量级大模型的医疗应用潜力 在医疗健康领域&#xff0c;数据隐私和响应速度是AI系统落地的核心挑战。传统的大型语言模型虽然能力强大&#xff0c;但往往依赖云端调用&#xff0c;存在数据…

作者头像 李华
网站建设 2026/2/15 20:59:58

Z-Image-Turbo API怎么调?二次开发入门指引

Z-Image-Turbo API怎么调&#xff1f;二次开发入门指引 你是不是已经用上了Z-Image-Turbo这个“文生图界的闪电侠”&#xff1f;8步出图、照片级画质、中文文字渲染不翻车&#xff0c;还支持消费级显卡运行——这些特性让它迅速成为AI绘画圈的新宠。但如果你只把它当做一个Web…

作者头像 李华
网站建设 2026/2/9 11:07:26

零基础入门AI角色扮演,gpt-oss-20b-WEBUI超简单

零基础入门AI角色扮演&#xff0c;gpt-oss-20b-WEBUI超简单 你是否曾幻想过和动漫里的经典角色面对面聊天&#xff1f;或者让一个虚拟人物陪你写故事、解心事&#xff1f;现在&#xff0c;借助开源AI模型和现成的镜像工具&#xff0c;这一切已经不再遥远。本文将带你从零开始&…

作者头像 李华
网站建设 2026/2/8 17:07:52

Sambert如何做A/B测试?多模型输出对比部署方案

Sambert如何做A/B测试&#xff1f;多模型输出对比部署方案 Sambert 多情感中文语音合成-开箱即用版&#xff0c;专为中文场景优化&#xff0c;支持知北、知雁等多发音人情感转换。本镜像基于阿里达摩院 Sambert-HiFiGAN 模型&#xff0c;已深度修复 ttsfrd 二进制依赖及 SciPy…

作者头像 李华
网站建设 2026/2/8 19:21:42

实测Qwen3-Reranker-4B:文本重排序效果超预期实战分享

实测Qwen3-Reranker-4B&#xff1a;文本重排序效果超预期实战分享 最近在做信息检索系统的优化&#xff0c;尝试了多个重排序&#xff08;Reranking&#xff09;模型后&#xff0c;最终把目光锁定在 Qwen3-Reranker-4B 上。这款由通义千问推出的40亿参数重排序模型&#xff0c…

作者头像 李华