Chinaunix

标题: SHELL 合并多行 谢谢了 [打印本页]

作者: gaopengtttt    时间: 2009-09-04 14:59
标题: SHELL 合并多行 谢谢了
由于是外行 所以 请教下 谢谢 下面的多行 如何合并
2009-9-1 8:47:47 Failure
woaini
2009-9-1 8:47:45 Failure

192.168.16.225
2009-9-1 8:40:37 Failure

2009-9-1 8:40:37 Failure
pppp
192.168.17.5
我想合并为如下格式
2009-9-1,8:47:47,Failure,woaini
2009-9-1,8:47:45,Failure,,192.168.16.225
2009-9-1,8:40:37,Failure
2009-9-1,8:40:37,Failure,pppp,192.168.17.5
主要用来SQL LOADR 导入ORACLE

谢谢了
作者: kwokcn    时间: 2009-09-04 15:25
awk

  1. awk -v RS="\n[0-9]+-[0-9]+-[0-9]+[^\n]+" '{gsub("\n",",");printf $0RT}{s=RT}END{print ""}' URFILE
复制代码

作者: wuhao1234wuhao    时间: 2009-09-04 15:31
awk '
/[0-9]+-[0-9]+-[0-9]+/{
        print ""
        for (i=1;i<=NF;i++) {
                printf("%s,",$i)
        }
END {print""}
}
$0 !~ /[0-9]+-[0-9]+-[0-9]+/ {printf (",%s",$0)}
' test.txt

cat test.txt
2009-9-1 8:47:47 Failure
woaini
2009-9-1 8:47:45 Failure

192.168.16.225
2009-9-1 8:40:37 Failure

2009-9-1 8:40:37 Failure
pppp
192.168.17.5
作者: gaopengtttt    时间: 2009-09-04 15:35
谢谢 大家 我试下
作者: gaopengtttt    时间: 2009-09-04 15:38
都有些问题 ,,不过谢谢了
作者: wuhao1234wuhao    时间: 2009-09-04 15:40
","控制不好。

RT是什么变量?
作者: kwokcn    时间: 2009-09-04 15:43
sed

  1. sed -nr '/[0-9]+-[0-9]+-[0-9]+/{x;s/\n/,/g;1!P;D};H;${x;s/\n/,/g;P;D}' URFILE
复制代码

这里最后$那里很啰嗦,不过"正则+行号"的或关系怎么用简洁的方式表达真没搞清楚,高手指教下啊~
作者: gaopengtttt    时间: 2009-09-04 15:46
kwokcn咋成这样了啊
,192.168.17.84:01 Failure,ASPNET
,192.168.17.84:01 Failure,ASPNET
,192.168.17.84:01 Failure,ASPNET
作者: kwokcn    时间: 2009-09-04 15:51
标题: 回复 #8 gaopengtttt 的帖子
环境?我平时都是用CentOS或者RH,HP-UX之类的用的少哈……
作者: ly5066113    时间: 2009-09-04 15:55
标题: 回复 #7 kwokcn 的帖子
是这个意思吧:
sed ':a;$!N;/\n2009/!s/\n/ /;ta;s/  */,/g;D' urfile
作者: gaopengtttt    时间: 2009-09-04 15:57
格式大概如下:
2009-9-1 19:03:02 Failure
zhang
192.168.16.137
2009-9-1 18:50:24 Failure

192.168.17.5
2009-9-1 18:50:24 Failure

2009-9-1 18:50:24 Failure
B000-A1041$
192.168.17.5
2009-9-1 18:45:58 Failure
Gao
192.168.17.135
作者: kwokcn    时间: 2009-09-04 16:14
原帖由 ly5066113 于 2009-9-4 15:55 发表
是这个意思吧:
sed ':a;$!N;/\n2009/!s/\n/ /;ta;s/  */,/g;D' urfile

:)
用标签来处理还是清爽的多啊~
我原来想用类似于awk的||或者什么东西把$那段去掉来着~ >_<
作者: cxfcxf    时间: 2009-09-04 17:17
"2009"当分隔符 \n 用,代替
出来的时候 在awk -F 分割一下
类似
$/ = "2009";
foreach (<DATA>) {
     chomp;
     s/\n/,/g;
     my ($a, $b, $c) = split /\ /,$_;
     print "2009$a\,$b\,$c\n";
}

这样 空行也会被计入一个空格 而不是当\n忽略掉
作者: gaopengtttt    时间: 2009-09-04 17:34
Gaopeng^M 这里的^M是啥? 我用VI 打开看到 就是它在作怪。。
作者: cnzhaopeng    时间: 2009-09-06 17:06
标题: 回复 #14 gaopengtttt 的帖子
dos2unix
windows下面的dos格式文件。




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2