在这里,我想删除与第四次出现的<li><p><a href="anti\/recent.html">匹配的行
我以前在这里问过,但这有点不同,那时我只需要和<ul>比赛。
当时我得到了答案:
awk '/<ul>/ {ul++} ul == 6 { getline } 1' file但是,在我尝试使用<li><p><a href="anti\/recent.html">时,不能将其应用于https://stackoverflow.com/questions/ask。
awk '/<li><p><a href="anti\/recent.html">/ {lipa href="anti\/recent.html"++} lipa href="anti\/recent.html" == 4 { getline } 1' file返回我的synatx错误。有人能帮上忙吗?谢谢
这些错误是:
awk: /<li><p><a href="anti\/recent.html">/ {lipa href="anti\/recent.html"++} lip a href="anti\/recent.html" == 4 { getline } 1
awk: ^ syntax error
awk: warning: escape sequence `\/' treated as plain `/'
awk: /<li><p><a href="anti\/recent.html">/ {lipa href="anti\/recent.html"++} lip a href="anti\/recent.html" == 4 { getline } 1
awk: ^ syntax error*继续:感谢任何人帮助这里的鹰似乎有一些错误
^I^I^I^I^I^I^I^I^I<li><p><a href="anti/recent.html">4 Jul 2011 - Fraudulent email purporting to be related to Standard Chartered Bank (Hong Kong) Limited</a></p></li>$
<!--<li>There is no phishing attack at this moment.</li>-->$
^I^I^I^I^I^I^I^I </ul>$它也将删除</ul>,尽管这是在不同的行?
我已经编辑并测试了:
#!/bin/bash
i=1 cat test2.html | while read -r
do
if [ "$(echo $REPLY | grep -E '<li><p><a href=\"anti/recent.html\">')" ]
then
let i++;
if [ ! "$i" -eq 4 ]
then
echo "$REPLY";
fi;
else
echo "$REPLY";
fi;
done > test2.html;对不对?当我执行代码并看到test2.html的结果时,它是一个没有任何内容的页面?没有html代码没有文本?谢谢。
发布于 2011-07-21 07:02:49
你一定要用awk做这件事?如果不是,这段代码可能会更清晰。
i=1 cat some_file | while read -r
do
if [ "$(echo $REPLY | grep -E '<li><p><a href=\"anti/recent.html\">')" ]
then
let i++;
if [ ! "$i" -eq 4 ]
then
echo "$REPLY";
fi;
else
echo "$REPLY";
fi;
done > fixed_file;https://stackoverflow.com/questions/6771336
复制相似问题