linux中如何对一个文件的内容进行处理,文件中每行有多个字段的值,中间用空格分隔开?

需求描述:

  今天在帮同事看个需求,将操作系统上的文件进行修改名字,改为特定的名字,所以呢,就先把这些原名字及对应的新名字关系放到了一个文本中,对于这个文本执行循环.

文件格式如下:

201803270000000000000.000000057100100000测试_提单测试.txt    20180725094809546000001.txt 
201803270000000000000.000000058100100000测试_提单测试.txt    20180725094809546000002.txt

操作过程:

1.通过while结合read命令对文件内容进行处理

#!/bin/bash
while read line 
do
    Orig_Name=$(echo $line | awk '{print $1}')   #获取文件原名字,也就是第一个字段
    New_Name=$(echo $line | awk '{print $2}')    #获取文件新的名字,也就是第二个字段,因为一行中包括两个信息,所以要这么处理touch $Orig_Name                             #模拟创建原文件
    cp $Orig_Name $New_Name                      #将文件拷贝成新的名字.
done < file02.txt    #读取文件中的内容.赋值给变量line.

备注:通过使用read的方式就将文件中的每一行都赋值给line变量,然后line变量在do...done中进行处理.

 

另:在测试的过程中,拷贝出来的文件名字的结尾有?,这个就要注意了.是由于在windows环境中创建文件导致的.建议,在linux环境中增加文件,或者直接在记事本中操作.不会有windows的结尾符.

 

文档创建时间:2018年7月25日14:20:58

posted @ 2018-07-25 14:23  Zhai_David  阅读(3709)  评论(0编辑  收藏  举报