标题: 如何用gawk只输出第一次找到的数据?
[打印本页]
作者: zts59
时间: 2008-8-23 12:09
标题: 如何用gawk只输出第一次找到的数据?
a.txt文本内容:
a1,b2,c3,d4,e5
a1,b2,c3,d4,e6
a1,b2,c3,d4,e7
a1,b2,c3,d4,e8
a1,b2,c3,d4,e9
用 gawk BEGIN { FS=","};/d4/{print $4,": "$5} a.txt>b.txt
出现结果:
d4:e5
d4:e6
d4:e7
d4:e8
d4:e9
如何控制只输出第一次的取值呢 就是:
d4:e5
谢谢,aa.txt只并没有规律
作者: pusofalse
时间: 2008-8-23 12:40
for /f "delims=" %%a in ('gawk BEGIN { FS=","};/d4/{print $4,": "$5} a.txt') do @echo>>b.txt %%a&pause&exit/b
作者: HAT
时间: 2008-8-23 13:27
print之前加个判断
if(NR==1)
作者: zts59
时间: 2008-8-23 17:33
目标文件里面内容可能不是第一行,pusofalse是通过FOR实现,在DOS下用不了
HAT所用IF是GAWK自带的参数?还是CMD里面的IF?
作者: metoo
时间: 2008-8-23 18:27
对于gawk我感觉直接命令行不是太稳定,个人倾向用调用脚本的形式
BEGIN {FS=","}
/d4/ {print "d4:"$5;exit}
[
Last edited by metoo on 2008-8-23 at 06:30 PM ]
作者: HAT
时间: 2008-8-23 19:37
看到NR==1应该能猜到是gawk里面的if吧:)
dos里面这样写行吗?
@echo off
gawk BEGIN { FS=","};/d4/{print $4,": "$5} a.txt>b.txt
set /p str=<b.txt
>c.txt echo.%str%
del b.txt
ren b.txt c.txt
作者: lxmxn
时间: 2008-8-24 00:55
直接这样就好了吧?
gawk -F, "/d4/{print $4 \": \" $5;exit}" a.txt > b.txt
to metoo:
可以说说gawk在命令行为什么不稳定吗?
to HAT:
感觉你的方法不行,不知道你测试过没呢?
作者: metoo
时间: 2008-8-24 06:30
Quote: |
Originally posted by lxmxn at 2008-8-24 12:55 AM:
直接这样就好了吧?
gawk -F, "/d4/{print $4 \": \" $5;exit}" a.txt > b.txt to metoo:
可以说说gawk在命令行为什么不稳定吗?
to HA ... |
|

其实我也没啥依据。。因为每次我写都是脚本写的,有次同样的正则在命令行下就是不行,脚本就行
作者: zts59
时间: 2008-8-25 08:17
Quote: |
Originally posted by lxmxn at 2008-8-24 12:55 AM:
直接这样就好了吧?
gawk -F, "/d4/{print $4 \": \" $5;exit}" a.txt > b.txt to metoo:
可以说说gawk在命令行为什么不稳定吗?
to HA ... |
|
谢谢版主,
请问一下,如果还要需要再增加入别的PRINT输出参数,那上次那个EXIT执行了后是不是不会执行后面的PRINT参数了?
作者: DXSX
时间: 2010-1-8 15:15
用管道
gawk BEGIN { FS=","};/d4/{print $4,": "$5} a.txt|gawk '{if (NR==1) print $0}'