shell 如何取文本中 指定两个字符中间的内容
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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
或者:
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 参考技术B ▶ 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";'
以上是关于shell 如何取文本中 指定两个字符中间的内容的主要内容,如果未能解决你的问题,请参考以下文章