我使用以下代码重命名当前文件夹中的所有图像:
a=1
for i in *.jpg; do
new=$(printf "%04d.jpg" ${a}); #04 pad to length of 4
mv ${i} ${new};
a=$((a+1));
done
但我遇到了一个问题:一些图像被覆盖了,因为我在文件夹中添加了更多图像后使用它.有没有办法来解决这个问题?我想添加一个if(name_exists)然后添加next_name,但我是脚本新手.有什么帮助吗?
最佳答案 您可以使用:
#!/bin/bash
glob="[0-9][0-9][0-9][0-9].jpg"
last=$(find . -maxdepth 1 -name "$glob" -print |sort -gr |grep -Pom1 '\d{4}') # or |grep -om1 '[0-9][0-9]*')
last=${last:-0}
while IFS= read -d $'\0' -r image
do
let last++
echo mv "$image" "$(printf "%04s" $last ).jpg"
done < <(find . -maxdepth 1 -name \*.jpg -a -not -name "$glob" -print0)
哪里:
> 1st find查找最后使用的数字
> while读取读取的输出
> 2找到什么发现所有.jpg有什么不同的名称为NNNN.jpg
>增加和重命名
你可以说明这一点
>搜索其他类型的图像(不仅仅是jpg)
>将脚本更改为不区分大小写
>如果图像数量增加到9999以上,上述情况将会失败……所以……
脚本处于干燥模式,满足时删除回声
编辑
破折号:
glob="[0-9][0-9][0-9][0-9].jpg"
last=$(find . -maxdepth 1 -name "$glob" -print |sort -gr |grep -Pom1 '\d{4}') # or |grep -om1 '[0-9][0-9]*')
last=${last:-0}
for image in *.jpg
do
echo "$image" | grep -q "^$glob$" && continue
#last=$((last+1)) #with leading zeroes, the numbers treated as octal... fails for 08 and such
last=$(expr $last + 1)
echo mv "$image" "$(printf "%04d" $last ).jpg"
done