Linux如何在多个文本文件中检索指定内容?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Linux如何在多个文本文件中检索指定内容?相关的知识,希望对你有一定的参考价值。
一个目录下有类似20XX-XX-XX_REQ.txt文档100多个,要从所有这些TXT文档当中找到某几个号码记录,应如何查找?最好性能高点!在线等,烦请各位大侠指导!
索搜的关键字不是一个,是多好号码。能一次都搜索出来吗?
grep "xxxx" *.txt追问
执行100次吗? 搜索的关键字放在命令的什么位置?
追答用通配符,一次就行。关键字就是xxx那里,如果是多个关键字,用|分隔开。即
grep 'xx|aa|bb' *.txt,这样。
关键字左右被单引号还是双引号包含?楼上是用双引号,关键字个数有限制吗?
追答单引、双引都可以,如果没有特殊字符的号。
关键字个数,不太清楚,正常的话,大概是255吧。
egrep "号码1|号码2|号码3" *REQ.txt 参考技术C # ls dir | grep 2*.txt 参考技术D grep "某几个号码" 20??-??-??_REQ.txt >> 1.txt
然后去vi 1.txt
你试试,我做了实验,成了
不会的再问我 第5个回答 2013-01-26 man grep自己看下
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";'
以上是关于Linux如何在多个文本文件中检索指定内容?的主要内容,如果未能解决你的问题,请参考以下文章