shell中awk问题:我想循环输出一个txt文件中第10列到第25列的内容
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了shell中awk问题:我想循环输出一个txt文件中第10列到第25列的内容相关的知识,希望对你有一定的参考价值。
我想循环输出一个txt文件中第10列到第25列的内容,awk怎么写?
我这样写的:
k=10
while [$k -le 25]
do
cat txt.txt|awk 'print $k '>sample.txt
......something else
done
测试发现程序中awk没有执行,如果想输出第十列那么就是awk‘print $10’ 可是现在列是个变量了,应该怎么写?我尝试了awk‘print$[$K]’是不对的,求助啊~~~~
awk 支持从shell中传参数。 参考技术A cat txt|cut -f10-25
工具是用来解决问题的,你却非要拿螺丝刀当锤子使.... 参考技术B 什么东东,任务而已
使用awk命令循环查找并修改后输出。
文件1.dat中保存如下数据
farfaef=ferAB.CD
fefhui=fgyijiAB.CD
ferhi=AB.CD
farfaef=ferFRE.CD
fefhui=fgyijiFF.CE
ferhi=FF.CO
文件2.dat中保存了如下数据
AB.CD
FRE.CD
FF.CE
FF.CO
1.dat的这些数据中要把“=”与2.dat中间的数据全部删除了,并且在3.dat输出结果如下。
farfaef=AB.CD
fefhui=AB.CD
ferhi=AB.CD
farfaef=FRE.CD
fefhui=FF.CE
ferhi=FF.CO
(注:元素数据一列,AB.CD数据一列)
个人理解是拿2.dat的每一行,去遍历1.dat,遇到哪一行有2.dat的数据就修改后输出到3.dat
问一下,是去掉的部分都是小写字母,而保留的2.dat中的都是大写字母和"."的组合吗;如果是的话,用下面的命令去掉等号后的非大写字母和非“.”的字符就可以了,如下:
awk 'gsub(/=[^A-Z.]*/,"=");print' 1.dat > 3.dat要是还是必须用题目上说的要求,再追问吧~
按照题目的要求的话,可以用以下命令实现:
awk -F '=' 'NR==FNRa[$0]NR!=FNRfor(i in a)if(match($2,i))print $1"="i;nextprint $0' 2.dat 1.dat > 3.dat上面的命令遇到1.dat中的后面部分没有在2.dat中出现的情况则会输出1.dat中原来的内容。如果不需要输出这些没有被替换的内容,则去掉最后的print即可。
追问无法输出3.dat
追答我运行的结果,是可以的,1.dat在最后一行加入了不命中的,最后结果会输入到3.dat,运行结果如下所示:
test$ cat 1.datfarfaef=ferAB.CD
fefhui=fgyijiAB.CD
ferhi=AB.CD
farfaef=ferFRE.CD
fefhui=fgyijiFF.CE
ferhi=FF.CO
ferhi=awdkwAB.BB
test$ cat 2.dat
AB.CD
FRE.CD
FF.CE
FF.CO
test$ awk -F '=' 'NR==FNRa[$0]NR!=FNRfor(i in a)if(match($2,i))print $1"="i;nextprint' 2.dat 1.dat > 3.dat
test$ cat 3.dat
farfaef=AB.CD
fefhui=AB.CD
ferhi=AB.CD
farfaef=FRE.CD
fefhui=FF.CE
ferhi=FF.CO
ferhi=awdkwAB.BB
test$ 参考技术A awk -F"=" 'NR==FNRa[$0]=$0NR>FNRfor(i in a)if($2 ~ i)print $1"="i' 2.dat 1.dat追问
能否把没有命中2.dat任何一行的数据也一起输出呢?
追答你给我的文本中,好像都命中了吧?
追问1中有一些注释什么的,都一起被删除了,我一开始忘了写明
追答其实上边那个人写的已经符合你的需求了,我俩思路是一样的。
awk -F"=" 'NR==FNRa[$0]=$0NR>FNRfor(i in a)if($2~i)print $1"="i;nextprint'以上是关于shell中awk问题:我想循环输出一个txt文件中第10列到第25列的内容的主要内容,如果未能解决你的问题,请参考以下文章
shell awk中如何实现 1 2 3 4 5 6 7 8 如何输出 1 2 3 4 5 6 7 8