[英]Using regular expression in bash script
我是bash脚本的新手,但我想执行以下操作:
我想检测FILE_1中的模式STRING_1“ STRING_2”,并将STRING_2附加到FILE_2
一种简单的方法可以做到这一点?
您的问题相当模糊; 但是我猜你想要什么
如果FILE_1中存在STRING_1,则将STRING_2附加到FILE_2
answer=`grep -c STRING_1 FILE_1`
if [ "$answer" -gt 0 ]
then
echo "$STRING_2" >> FILE_2
fi
您可以执行以下操作:
sed 's/STRING_1 \"(.*)\"/\1/g' FILE_1 >FILE_2
sed在这里发生的事情是搜索FILE_1中第一个和第二个“ /”之间的所有内容,并将第二个和第三个“ /”之间的内容发送到FILE_2。
()组已分配给\\ 1,\\ 2等...,因此\\“之间的所有内容都是您的STRING_2。
grep -Po '(?<=aaa ")([^"]*)(?=")' FILE_1 >> FILE_2
如果我对问题的理解正确,那么您有一个包含以下内容的文件:
word1a "word1b"
word2a "word2b"
word3a "word3b"
您可以使用sed提取引号之间包含的值,然后重定向到文件
sed 's/.*"\(.*\)"/\1/' FILE_1 > FILE_2
您也可以使用此:
grep '^\s*STRING_1\s*\".*\"\s*$' FILE_1 | awk -F \" '{printf $2"\n"}' >> FILE_2
它将正确处理输入文件的多个空白字符,并在FILE_2的末尾在STRING_2之后添加换行符。
这就是我现在所拥有的:
sed's / STRING_1 \\ s *:\\ s *“([^”] *)“ / \\ 1 / g'” FILE_1“ >> FILE_2;
我希望它检测文件1中的以下模式:
STRING_1 : "STRING_2"
并将STRING_2保存到文件2
但这是行不通的,它会向FILE_2附加很多随机内容(不应该匹配)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.