我有这些文件:
NIHMS735398-supplement-Supplemental_Table_-_Top_Down_MS_Identificaitons.csv.0
NIHMS735398-supplement-Supplemental_Table_-_Top_Down_MS_Identificaitons.csv.1
NIHMS735398-supplement-Supplemental_Table_-_Top_Down_MS_Identificaitons.csv.2
NIHMS735398-supplement-Supplemental_Table_-_Top_Down_MS_Identificaitons.csv.3
NIHMS735398-supplement-Supplemental_Table_-_Top_Down_MS_Identificaitons.csv.4
我想像这样重命名:
NIHMS735398-supplement-Supplemental_Table_-_Top_Down_MS_Identificaitons_1.csv
NIHMS735398-supplement-Supplemental_Table_-_Top_Down_MS_Identificaitons_2.csv
NIHMS735398-supplement-Supplemental_Table_-_Top_Down_MS_Identificaitons_3.csv
NIHMS735398-supplement-Supplemental_Table_-_Top_Down_MS_Identificaitons_4.csv
NIHMS735398-supplement-Supplemental_Table_-_Top_Down_MS_Identificaitons_5.csv
我尝试了以下方法(以及一些变体(,但没有成功:
rename -v 's/(NIHMS.+tons).csv.+/1_[0-9].csv/' *.csv*
和
ls *csv* | sed -E 's/(NIHM.+tons).csv.*$/1_{1..5}.csv/'
和
ls *csv* | cat -n | while read n f; do mv "$f" "$f_$n.csv"; done
我得到的最接近的是使用最后一个给我这样的
:1.csv 2.csv 3.csv 4.csv 5.csv
我很确定我可以使用 python 来做到这一点,但我正在尝试通过命令行/bash 并且最好使用正则表达式(我正在努力更好地学习(。
使用 sed 创建新名称,保存文件名的各个部分并交换它们:
for file in *.csv.[0-9]*; do
new_name=$( echo $file | sed 's/(.*).csv.([0-9]*)/1_2.csv/' )
echo mv $file $new_name
done
为了安全起见,我在 mv 前面放了回声。 如果结果看起来不错,请取出回声。 以下是我的结果:
[jack@marta ~]$ for file in *.csv.[0-9]*; do new_name=$(echo $file | sed 's/(.*).csv.([0-9]*)/1_2.csv/'); echo mv $file $new_name; done
mv NIHMS735398-supplement-Supplemental_Table_-_Top_Down_MS_Identificaitons.csv.0 NIHMS735398-supplement-Supplemental_Table_-_Top_Down_MS_Identificaitons_0.csv
mv NIHMS735398-supplement-Supplemental_Table_-_Top_Down_MS_Identificaitons.csv.1 NIHMS735398-supplement-Supplemental_Table_-_Top_Down_MS_Identificaitons_1.csv
mv NIHMS735398-supplement-Supplemental_Table_-_Top_Down_MS_Identificaitons.csv.10 NIHMS735398-supplement-Supplemental_Table_-_Top_Down_MS_Identificaitons_10.csv
mv NIHMS735398-supplement-Supplemental_Table_-_Top_Down_MS_Identificaitons.csv.11 NIHMS735398-supplement-Supplemental_Table_-_Top_Down_MS_Identificaitons_11.csv
mv NIHMS735398-supplement-Supplemental_Table_-_Top_Down_MS_Identificaitons.csv.2 NIHMS735398-supplement-Supplemental_Table_-_Top_Down_MS_Identificaitons_2.csv
mv NIHMS735398-supplement-Supplemental_Table_-_Top_Down_MS_Identificaitons.csv.3 NIHMS735398-supplement-Supplemental_Table_-_Top_Down_MS_Identificaitons_3.csv
mv NIHMS735398-supplement-Supplemental_Table_-_Top_Down_MS_Identificaitons.csv.4 NIHMS735398-supplement-Supplemental_Table_-_Top_Down_MS_Identificaitons_4.csv
mv NIHMS735398-supplement-Supplemental_Table_-_Top_Down_MS_Identificaitons.csv.5 NIHMS735398-supplement-Supplemental_Table_-_Top_Down_MS_Identificaitons_5.csv
mv NIHMS735398-supplement-Supplemental_Table_-_Top_Down_MS_Identificaitons.csv.6 NIHMS735398-supplement-Supplemental_Table_-_Top_Down_MS_Identificaitons_6.csv
mv NIHMS735398-supplement-Supplemental_Table_-_Top_Down_MS_Identificaitons.csv.7 NIHMS735398-supplement-Supplemental_Table_-_Top_Down_MS_Identificaitons_7.csv
mv NIHMS735398-supplement-Supplemental_Table_-_Top_Down_MS_Identificaitons.csv.8 NIHMS735398-supplement-Supplemental_Table_-_Top_Down_MS_Identificaitons_8.csv
mv NIHMS735398-supplement-Supplemental_Table_-_Top_Down_MS_Identificaitons.csv.9 NIHMS735398-supplement-Supplemental_Table_-_Top_Down_MS_Identificaitons_9.csv
[jack@marta ~]$
一种方法是使用 bash 参数替换:
for f in *.csv.* ; do d="${f##*.}" ; mv "$f" "${f%*.csv*}__$((d+1)).csv" ; done
d
变量设置为文件名中的最后一个数字,然后在mv
中替换它。
使用 Bash 正则表达式:
re='(.*).csv.([[:digit:]]+)$'
for f in *; do
[[ $f =~ $re ]]
echo mv "$f" "${BASH_REMATCH[1]}_$(( ${BASH_REMATCH[2]} + 1 )).csv"
done
当输出看起来正确时,可以删除echo
。
如果目标不是增加输入文件编号,而是从 1 开始按顺序编号的文件,则可以将代码更改为以下内容:
re='(.*).csv.[[:digit:]]+$' # Just one capture group
i=1
for f in *; do
[[ $f =~ $re ]]
echo mv "$f" "${BASH_REMATCH[1]}_$(( i++ )).csv"
done
现在文件将被编号为1,2,3,...按字母顺序输入。
未经测试,因为我不在电脑前,但基于你自己对rename
的努力,这应该很接近:
rename -n '($a,$b)=split /.csv./; $_=$a . ($b+1) . ".csv"' *csv*
split
应该将".csv."之前的所有内容放入$a
,将其之后的所有内容放入$b
。第二部分将输出($_
(设置为$a
后跟附加".csv"的$b+1
。