shell 如何取文本中 指定两个字符中间的内容

要取TABLE "bank".与row size中间的字符串 如下面的:cpdmdyb_ck
{ TABLE "bank".cpdmdyb_ck row size = 143 number of columns = 3 index size = 106 }
{ unload file name = cpdmd06141.unl number of rows = 1822 }

{ TABLE "bank".cpdmdyb_dk row size = 143 number of columns = 3 index size = 106 }
{ unload file name = cpdmd06143.unl number of rows = 12310 }

第1个回答  2014-11-12
sed -nr '/TABLE/{s/.*"bank"\.(.+) row.*/\1/;p}' yourfile

或者:

awk -F. '/TABLE/{split($2,a," ");print a[1]}' yourfile

结果都是:

cpdmdyb_ck

cpdmdyb_dk

追问

这个可以用非常感谢,第二行带.unl的怎么取出来呢,如:cpdmd06141.unl

追答

我看到你的另一个提问了,见那个回答。
用sed的N命令将TABLE "bank"的下一行也读取到模式空间内,并合并为一行(换行符\n分隔)后一起处理。

追问

你在那里面把脚本写出来嘛,我不会写,我在那边把分给你

追答

那边写出来了。这里也放一下。

sed -nr '/TABLE/{N;s/.*"bank"\.(.+) row.*\n.*name = (.+) number.*/load from \2 insert into \1;/;p}' file.txt

第2个回答  2014-11-11
▶ xsel -o|perl -e '$_=<>; /bank\"\.(.*)row/; print $1;'
cpdmdyb_ck追问

文件名在那里啊

追答

cat xxxx文件名|perl -e 'while($_=){ /bank\"\.(.*)row/; print $1;}'

追问

我要用 TABLE "bank".与row size TABLE 加在那呢,取出来要显示为:
cpdmdyb_ck
cpdmdyb_dk
上面的命令显示在一行了如下
cpdmdyb_ck cpdmdyb_dk
帮我再改下,非常感谢
能不能把下面的cpdmd06141.unl 与cpdmdyb_ck连接起来比如:
laod from cpdmd06141.unl insert into cpdmdyb_ck

追答

最后的输出,改成这样
print "$1\n"

就是附加一个回车。

追问

执行后输出的内容中有重复记录:
ryjsb
ryjsb
khjltzb
khjltzb
khb
khb
grkhfzb
grkhfzb
khsfqrb
khsfqrb
文本中没有重复的行

追答

哦。我以为你的数据是规则的,每行都有。加一个判断就是。

cat xxxxx|perl -e 'while(){ if(/bank\"\.(.*)row/){print "$1\n";}}'

本回答被网友采纳

相关了解……

你可能感兴趣的内容

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 非常风气网