grep
//ファイルawk
内の特定のパターンを見つけて行全体を印刷するにはどうすればよいですか(一致する行は?sed
\
ファイルfoo.txt
には以下が含まれます。
something
whatever
thisXXX line \
has a continuation line
blahblah
a \
multipleXXX \
continuation \
line
取得するにはどうすればよいですか(必ず1行で書く必要はなく、複数のスペースを削除する必要もありません):
thisXXX line has a continuation line
a multipleXXX continuation line
ところで、私はbashとfedora21を使用しているので、POSIXと互換性がある必要はありません(しかしPOSIXなら感謝します)。
ベストアンサー1
\
Perlを使用して先行する改行とスペースを削除する別の方法:
$ perl -pe 's/\\\n/ /' file | grep XXX
thisXXX line has a continuation line
a multipleXXX continuation line
余分なスペースを削除するには、sedで渡します。
$ perl -pe 's/\\\n/ /' file | grep XXX | sed 's/ */ /g'
thisXXX line has a continuation line
a multipleXXX continuation line