zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    MongoDB学习笔记(一) MongoDB介绍及安装
    MVC DefaultControllerFactory代码分析
    WCF中的变更处理
    分布式文档存储数据库 MongoDB
    wcf学习资料
    vs2010打包安装
    Android语音识别RecognizerIntent
    Eclipse快捷键
    甲骨文公司老板埃里森在耶如大学的…
    Android&nbsp;TTS语音识别
  • 原文地址:https://www.cnblogs.com/chuanzhang053/p/9365738.html
Copyright © 2011-2022 走看看