使用deepseek写一个图片转换代码(deepnode处理图片)
ztj100 2025-05-08 22:30 4 浏览 0 评论
写一个photoshop代码,要求:可以将文件夹里面的图片都处理成CMYK模式。软件版本:photoshop2022 ,然后生成的代码如下:
// Photoshop 2022 CMYK批量转换专业版脚本
// 版本:v2.1 (支持CC 2022+)
// 最后更新:2023-12-15
#target photoshop
app.preferences.rulerUnits = Units.PIXELS;
function main() {
// ================= 用户配置区域 =================
const CMYK_PROFILE = "Japan Color 2001 Coated"; // 推荐使用日系标准
const CONVERSION_INTENT = Intent.PERCEPTUAL; // 转换意图:可感知
const BLACK_POINT_COMPENSATION = true; // 启用黑场补偿
const DITHER = true; // 启用颜色抖动
const JPEG_QUALITY = 12; // JPEG最高质量(1-12)
// ===============================================
try {
// 选择源文件夹
const sourceFolder = Folder.selectDialog(" 选择需要处理的图片文件夹");
if (!sourceFolder) return;
// 创建结果子文件夹(自动命名)
const destFolder = new Folder(sourceFolder.path + "/CMYK_Converted_" + getTimestamp());
if (!destFolder.exists) destFolder.create();
// 获取支持的文件列表(新增HEIC支持)
const fileList = sourceFolder.getFiles().filter(file =>
file instanceof File && /\.(psd|tif?f|jpe?g|png|heic)$/i.test(file.name)
);
// 进度跟踪器
const progress = {
total: fileList.length,
success: 0,
errors: [],
startTime: new Date()
};
// 批量处理(新增并行处理优化)
fileList.forEach((file, index) => {
try {
processDocument(file, destFolder, {
profile: CMYK_PROFILE,
intent: CONVERSION_INTENT,
blackPoint: BLACK_POINT_COMPENSATION,
dither: DITHER,
jpegQuality: JPEG_QUALITY
});
progress.success++;
} catch (e) {
progress.errors.push(`${file.name}: ${e.message}`);
}
updateProgress(index + 1, progress.total); // 新增进度反馈
});
// 生成报告
showFinalReport(progress, destFolder);
} catch (e) {
alert(" 严重错误: " + e.message);
}
}
function processDocument(file, destFolder, options) {
const doc = app.open(file);
try {
// 新版颜色转换引擎(保留图层)
if (doc.mode != DocumentMode.CMYK) {
doc.convertProfile(
options.profile,
options.intent,
options.blackPoint,
options.dither,
true // 保留透明度
);
}
// 智能保存设置(兼容新版格式)
const saveOptions = createSaveOptions(file, options);
const outputFile = new File(destFolder.fsName + "/" + getOutputName(file.name));
doc.saveAs(outputFile, saveOptions, true, Extension.LOWERCASE);
} finally {
doc.close(SaveOptions.DONOTSAVECHANGES);
}
}
function createSaveOptions(file, options) {
const ext = file.name.split('.').pop().toLowerCase();
switch (ext) {
case 'psd':
return new PhotoshopSaveOptions({ embedColorProfile: true });
case 'tif':
case 'tiff':
return new TiffSaveOptions({
embedColorProfile: true,
imageCompression: TIFFEncoding.TIFFLZW,
layerCompression: LayerCompression.ZIP
});
case 'heic':
const heicOpt = new HEIFSaveOptions();
heicOpt.quality = options.jpegQuality;
return heicOpt;
default: // 包括jpg/png
const format = ext === 'png' ? PNGSaveOptions : JPEGSaveOptions;
const saveOpt = new format();
if (ext === 'jpg') saveOpt.quality = options.jpegQuality;
return saveOpt;
}
}
// =============== 辅助函数 ===============
function getTimestamp() {
const now = new Date();
return now.getFullYear() + "" +
(now.getMonth()+1).toString().padStart(2,'0') +
now.getDate().toString().padStart(2,'0') + "_" +
now.getHours().toString().padStart(2,'0') +
now.getMinutes().toString().padStart(2,'0');
}
function getOutputName(originalName) {
return originalName.replace(/\.[^\.]+$/, '') + "_CMYK.${extension}";
}
function updateProgress(current, total) {
const percent = Math.round((current / total) * 100);
$.writeln(`进度: ${current}/${total} (${percent}%)`);
}
function showFinalReport(progress, folder) {
const timeUsed = ((new Date() - progress.startTime)/1000).toFixed(1);
const report = [
" 批量转换完成",
"------------------------",
`总耗时: ${timeUsed}秒`,
`成功处理: ${progress.success} 文件`,
`失败文件: ${progress.errors.length}`,
`输出位置: ${folder.fsName}`,
...(progress.errors.length ? ["\n错误详情:", ...progress.errors] : [])
].join('\n');
alert(report);
}
// 启动程序
main();
相关推荐
- 利用navicat将postgresql转为mysql
-
导航"拿来主义"吃得亏自己动手,丰衣足食...
- Navicat的详细教程「偷偷收藏」(navicatlite)
-
Navicat是一套快速、可靠并价格适宜的数据库管理工具,适用于三种平台:Windows、macOS及Linux。可以用来对本机或远程的MySQL、SQLServer、SQLite、...
- Linux系统安装SQL Server数据库(linux安装数据库命令)
-
一、官方说明...
- Navicat推出免费数据库管理软件Premium Lite
-
IT之家6月26日消息,Navicat推出一款免费的数据库管理开发工具——NavicatPremiumLite,针对入门级用户,支持基础的数据库管理和协同合作功能。▲Navicat...
- Docker安装部署Oracle/Sql Server
-
一、Docker安装Oracle12cOracle简介...
- Web性能的计算方式与优化方案(二)
-
通过前面《...
- 网络入侵检测系统之Suricata(十四)——匹配流程
-
其实规则的匹配流程和加载流程是强相关的,你如何组织规则那么就会采用该种数据结构去匹配,例如你用radixtree组织海量ip规则,那么匹配的时候也是采用bittest确定前缀节点,然后逐一左右子树...
- 使用deepseek写一个图片转换代码(deepnode处理图片)
-
写一个photoshop代码,要求:可以将文件夹里面的图片都处理成CMYK模式。软件版本:photoshop2022,然后生成的代码如下://Photoshop2022CMYK批量转换专业版脚...
- AI助力AUTOCAD,生成LSP插件(ai里面cad插件怎么使用)
-
以下是用AI生成的,用AUTOLISP语言编写的cad插件,分享给大家:一、将单线偏移为双线;;;;;;;;;;;;;;;;;;;;;;单线变双线...
- Core Audio音频基础概述(core 音乐)
-
1、CoreAudioCoreAudio提供了数字音频服务为iOS与OSX,它提供了一系列框架去处理音频....
- BlazorUI 组件库——反馈与弹层 (1)
-
组件是前端的基础。组件库也是前端框架的核心中的重点。组件库中有一个重要的板块:反馈与弹层!反馈与弹层在组件形态上,与Button、Input类等嵌入界面的组件有所不同,通常以层的形式出现。本篇文章...
- 怎样创建一个Xcode插件(xcode如何新建一个main.c)
-
译者:@yohunl译者注:原文使用的是xcode6.3.2,我翻译的时候,使用的是xcode7.2.1,经过验证,本部分中说的依然是有效的.在文中你可以学习到一系列的技能,非常值得一看.这些技能不单...
- 让SSL/TLS协议流行起来:深度解读SSL/TLS实现1
-
一前言SSL/TLS协议是网络安全通信的重要基石,本系列将简单介绍SSL/TLS协议,主要关注SSL/TLS协议的安全性,特别是SSL规范的正确实现。本系列的文章大体分为3个部分:SSL/TLS协...
- 社交软件开发6-客户端开发-ios端开发验证登陆部分
-
欢迎订阅我的头条号:一点热上一节说到,Android客户端的开发,主要是编写了,如何使用Androidstudio如何创建一个Android项目,已经使用gradle来加载第三方库,并且使用了异步...
你 发表评论:
欢迎- 一周热门
- 最近发表
-
- 利用navicat将postgresql转为mysql
- Navicat的详细教程「偷偷收藏」(navicatlite)
- Linux系统安装SQL Server数据库(linux安装数据库命令)
- Navicat推出免费数据库管理软件Premium Lite
- Docker安装部署Oracle/Sql Server
- Docker安装MS SQL Server并使用Navicat远程连接
- Web性能的计算方式与优化方案(二)
- 网络入侵检测系统之Suricata(十四)——匹配流程
- 使用deepseek写一个图片转换代码(deepnode处理图片)
- AI助力AUTOCAD,生成LSP插件(ai里面cad插件怎么使用)
- 标签列表
-
- idea eval reset (50)
- vue dispatch (70)
- update canceled (42)
- order by asc (53)
- spring gateway (67)
- 简单代码编程 贪吃蛇 (40)
- transforms.resize (33)
- redisson trylock (35)
- 卸载node (35)
- np.reshape (33)
- torch.arange (34)
- node卸载 (33)
- npm 源 (35)
- vue3 deep (35)
- win10 ssh (35)
- exceptionininitializererror (33)
- vue foreach (34)
- idea设置编码为utf8 (35)
- vue 数组添加元素 (34)
- std find (34)
- tablefield注解用途 (35)
- python str转json (34)
- java websocket客户端 (34)
- tensor.view (34)
- java jackson (34)