我正在尝试使用*.ics
过滤sed
文件。 *.ics
文件如下所示:
[...]
BEGIN:VEVENT
UID:0xfoo
SUMMARY:foo
DTSTART:20131212T090000
DTEND:20131212T100000
SEQUENCE:0
DTSTAMP:20131212T100000
LOCATION:foo
CATEGORIES:foo
DESCRIPTION:foo
CLASS:PUBLIC
END:VEVENT
[...]
我想删除以使用UID
或SEQUENCE
,但仅当它们在之间 BEGIN:VEVENT
和END:VEVENT
我尝试使用以下方式删除这些行:
sed '/^BEGIN:VEVENT/,/^END:VEVENT/ /^UID/d'
但是它只会返回一个错误,例如unknown command '/'
如何删除这些行?
谢谢!
尝试此行:
sed '/^BEGIN:VEVENT/,/^END:VEVENT/{/^\(UID\|SEQUENCE\)/d}' file
sed是在单行上进行简单替换的出色工具,对于其他任何操作,只需使用awk:
awk '
/BEGIN:VEVENT/ { inBlock = 1 }
inBlock {
if ( /END:VEVENT/ ) {
inBlock = 0
}
else if ( /^(UID|SEQUENCE)/ ) {
next
}
}
{ print }
' file
伪代码说明(inBlock
是一个布尔变量,line
只是一个虚拟的字符串变量:]
WHILE read line from file DO
IF ( line contains the regexp "BEGIN:VEVENT" ) THEN
inBlock = TRUE
ENDIF
IF ( inBlock == TRUE ) THEN
IF ( line contains the regexp "END:VEVENT" ) THEN
inBlock = FALSE
ELSIF ( line starts with the regexp "UID" or "SEQUENCE" ) THEN
do no further processing on this line
ENDIF
ENDIF
print the current line
ENDWHILE
另一个awk
awk '/^BEGIN:VEVENT/,/^END:VEVENT/ {if ($0~/^UID|^SEQUENCE/) next}1' file
如果从UID
到SEQUENCE
的块部分中的行以BEGIN:VEVENT
或END:VEVENT
开头,则跳过该行