如何仅在文件不匹配模式时重命名文件?
How can I rename files only if they don't match a pattern?
我想通过将“-renamed”附加到扩展名之前的基本名称来重命名文件,但我也不想重命名已经具有“-renamed”字符串的文件。
例如,
IMG_1234.jpg -> IMG_1234-renamed.jpg
IMG_1235.mp4 -> IMG_1235-renamed.mp4
IMG_1236-renamed.jpg -> no change
对于第一部分,我有以下工作:
for f in *.jpg; do mv $f ${f%.jpg}-renamed.jpg; done
for f in *.mp4; do mv $f ${f%.mp4}-renamed.mp4; done
如何确保后续运行不会一遍又一遍地添加字符串?
IMG_1234-renamed.jpg -> IMG_1234-renamed-renamed.jpg
IMG_1235-renamed.mp4 -> IMG_1235-renamed-renamed.mp4
使用扩展的 globbing:
#!/bin/bash
shopt -s extglob
for f in !(*-renamed).@(jpg|mp4) ; do
new=${f%.*}
new+=-renamed.${f##*.}
if [[ -e $new ]] ; then
echo Skipped: "$new" already exists. >&2
else
mv "$f" "$new"
fi
done
!(*-renamed)
将匹配任何不以 -renamed
; 结尾的内容
@(jpg|mp4)
匹配 jpg
或 mp4
;
${f##*.}
returns 扩展名(即使基本名称包含几个点)。
- 此外,引用您的变量,以便脚本适用于包含空格的文件名。
- 此外,检查目标文件是否存在,以免不小心覆盖以前重命名的文件。
我想通过将“-renamed”附加到扩展名之前的基本名称来重命名文件,但我也不想重命名已经具有“-renamed”字符串的文件。
例如,
IMG_1234.jpg -> IMG_1234-renamed.jpg
IMG_1235.mp4 -> IMG_1235-renamed.mp4
IMG_1236-renamed.jpg -> no change
对于第一部分,我有以下工作:
for f in *.jpg; do mv $f ${f%.jpg}-renamed.jpg; done
for f in *.mp4; do mv $f ${f%.mp4}-renamed.mp4; done
如何确保后续运行不会一遍又一遍地添加字符串?
IMG_1234-renamed.jpg -> IMG_1234-renamed-renamed.jpg
IMG_1235-renamed.mp4 -> IMG_1235-renamed-renamed.mp4
使用扩展的 globbing:
#!/bin/bash
shopt -s extglob
for f in !(*-renamed).@(jpg|mp4) ; do
new=${f%.*}
new+=-renamed.${f##*.}
if [[ -e $new ]] ; then
echo Skipped: "$new" already exists. >&2
else
mv "$f" "$new"
fi
done
!(*-renamed)
将匹配任何不以-renamed
; 结尾的内容
@(jpg|mp4)
匹配jpg
或mp4
;${f##*.}
returns 扩展名(即使基本名称包含几个点)。- 此外,引用您的变量,以便脚本适用于包含空格的文件名。
- 此外,检查目标文件是否存在,以免不小心覆盖以前重命名的文件。