16

sed やその他の標準的な UNIX ツールなどを使用して、テキスト ファイルが空の場合、テキスト ファイルの最初の (!) 行を削除するにはどうすればよいですか。私はこのコマンドを試しました:

sed '/^$/d' < somefile

ただし、空の場合、ファイルの最初の行ではなく、最初の空の行が削除されます。行番号に関して、sedにいくつかの条件を与えることはできますか?

Levonの答えで、awkに基づいてこの小さなスクリプトを作成しました:

#!/bin/bash

for FILE in $(find some_directory -name "*.csv")
do
    echo Processing ${FILE}

    awk '{if (NR==1 && NF==0) next};1' < ${FILE} > ${FILE}.killfirstline
    mv ${FILE}.killfirstline ${FILE}

done
4

5 に答える 5

27

sed で最も簡単なことは次のとおりです。

sed '1{/^$/d}'

これはすべての空白を含む行を削除するのではなく、単一の改行のみを含む行のみを削除することに注意してください。空白を取り除くには:

sed '1{/^ *$/d}'

すべての空白を削除するには:

sed '1{/^[[:space:]]*$/d}'
于 2012-06-27T16:19:09.510 に答える
3

sedを使用して、これを試してください。

sed -e '2,$b' -e '/^$/d' < somefile

またはその場で変更を加えるには:

sed -i~ -e '2,$b' -e '/^$/d' somefile
于 2012-06-27T13:41:14.610 に答える
3

これをインプレースで行う必要がない場合はawk、出力を使用して別のファイルにリダイレクトできます。

awk '{if (NR==1 && NF==0) next};1' somefile

NR == 1これにより、最初の行 ( ) でデータが含まれていない( )場合を除いて、ファイルの内容が出力されますNF == 0

NR現在の行番号、NF空白/タブで区切られた特定の行のフィールド数

例えば、

$ cat -n data.txt
     1  
     2  this is some text
     3  and here
     4  too
     5  
     6  blank above
     7  the end

$ awk '{if (NR==1 && NF==0) next};1' data.txt | cat -n
     1  this is some text
     2  and here
     3  too
     4  
     5  blank above
     6  the end

cat -n data2.txt
     1  this is some text
     2  and here
     3  too
     4  
     5  blank above
     6  the end

$ awk '{if (NR==1 && NF==0) next};1' data2.txt | cat -n
     1  this is some text
     2  and here
     3  too
     4  
     5  blank above
     6  the end

更新

このsedソリューションは、インプレース置換にも機能するはずです。

sed -i.bak '1{/^$/d}'  somefile

.bak元のファイルは拡張子を付けて保存されます

于 2012-06-27T13:15:07.303 に答える
1

最初の行が空の場合、実際のディレクトリの下にあるすべてのファイルの最初の行を削除します。
find -type f | xargs sed -i -e '2,$b' -e '/^$/d'

于 2015-01-05T13:31:26.997 に答える
0

これはあなたのために働くかもしれません:

sed '1!b;/^$/d' file
于 2012-06-27T15:49:55.567 に答える