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
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
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