SED删除两个模式之间的特定行吗?

问题描述 投票:3回答:3

我正在尝试使用*.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

[...]

我想删除以使用UIDSEQUENCE,但仅当它们在之间 BEGIN:VEVENTEND:VEVENT

我尝试使用以下方式删除这些行:

sed '/^BEGIN:VEVENT/,/^END:VEVENT/ /^UID/d'

但是它只会返回一个错误,例如unknown command '/'

如何删除这些行?

谢谢!

design-patterns sed icalendar
3个回答
9
投票

尝试此行:

 sed '/^BEGIN:VEVENT/,/^END:VEVENT/{/^\(UID\|SEQUENCE\)/d}' file

5
投票

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

1
投票

另一个awk

awk '/^BEGIN:VEVENT/,/^END:VEVENT/ {if ($0~/^UID|^SEQUENCE/) next}1' file

如果从UIDSEQUENCE的块部分中的行以BEGIN:VEVENTEND:VEVENT开头,则跳过该行

© www.soinside.com 2019 - 2024. All rights reserved.