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