按顺序重命名文件,保留名称的第一部分



我有这些文件:

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

最新更新