2

我喜欢使用 AWK 或 SED 将 {st,corridor,tunnel} 之后的行合并为一行

Input 

abcd 
efgjk
st 
wer
dfgh
corridor 
weerr
tunnel 
twdf

Desired output


abcd  
efgjk st  
wer 
dfgh corridor  
weerr tunnel 
twdf
4

4 回答 4

2

一种使用方式awk

awk '!/st|corridor|tunnel/ { if (line) print line; line = $0; next } { line = line " " $0 } END { print line }' file.txt

结果:

abcd 
efgjk st 
wer
dfgh corridor 
weerr tunnel 
twdf
于 2012-07-27T06:53:19.370 回答
1

这可能对您有用(GNU sed):

sed '$!N;s/\n\(st\|corridor\|tunnel\)\s*$/ \1/;P;D' file
于 2012-07-27T06:33:12.740 回答
1

或者,首先将整个文件读入内存的 awk 版本(不推荐用于大文件):

$ awk 'BEGIN {i=1} {line[i++] = $0} END {j=1; while (j<i) {if (match(line[j+1], /^(st|corridor|tunnel)$/)) {print line[j] " " line[j+1]; j+=2} else print line[j++];}}' streets
abcd
efgjk st
wer
dfgh corridor
weerr tunnel
twdf

我将留给你一次做一两行的练习。:)

于 2012-07-27T06:43:44.907 回答
1

awk

BEGIN {
    s["st"]=s["corridor"]=s["tunnel"]
}

$1 in s {
    print prev, $1
}

!($1 in s) {
    if (prev) print prev
    prev = $1
}
于 2012-07-27T06:52:17.350 回答