Linux shell 读取一个data文件,扫描其中的一个内容

来源:互联网 发布:四川大学软件工程学院 编辑:程序博客网 时间:2024/06/05 18:38

程序功能:首先要读取一个data文件(很大),扫描出fr=..(文件中fr大概只有7种,并且某几种的value还有空值的情况。要处理空值 同时删除重复的内容)【为什么我觉得我没表达清楚。


代码如下:

   rz filename  #先将所要处理的文件上传到服务器(此处是data文件)   grep –r “fr= ” filename >filename1  #筛选filename中有”fr=”此关键字的行,并将其存到filename1文件中   awk ‘{print $3 ,$4} ’ filename1 >filename2  #只单独列出含fr的一列并存在filename2中($4的原因是fr的value存在空值的情况)   cat filename2 |where read line   #一行一行的读filename2中的内容 并将每行内容存在line   do   echo ${line%ldip1*}    # ${}是一个正则表达式 作用为删除每行中以ldip1开头后面的内容   done >filename3   #将内容存在filename3中   sort –k2n filename3 | uniq >filename4  #排序后 删除重复的内容

用Linux shell 命令处理文件中的内容的方式有三种:

1.cat file | while read linedo echo ${搞一个正则表达式很方便}done2.while read linedo echo ${搞一个正则表达式很方便}done3.for line in 'cat file'doecho ${搞一个正则表达式很方便}done

这三种方法是我搜到的 亲测好用 分享给大家

0 0