質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.33%

  • シェル

    257questions

    シェル(shell)はUnix や Linux 系のOSで使用されるコマンドインタプリタを指します。

sedコマンドでテキスト削除

解決済

回答 3

投稿

  • 評価
  • クリップ 0
  • VIEW 345
退会済みユーザー

退会済みユーザー

Apacheのログファイルからエラーログを抽出して本日以外の行を削除しようとしています。
でも、どうすれば良いのか分からず前日でも消えればと思い試行錯誤していました。
[09/Apr/2017:05:43:41 +0900]
上記のようなログの日付部分だけで判断すれば良いと考え

LANG=C
day=`date +'%d/%h/%Y' --date "1 days ago"`

grep " 404 " access_log > error_log.txt
sed -i -e "/$day/d" error_log.txt


上記のようにしました所、エラーをerror_log.txtに抜き出すのはできるのですが
最後の削除でエラーが出てしまいます。
デバッグしましたら

+ LANG=C
++ date +%d/%h/%Y --date '1 days ago'
+ day=09/Apr/2017
+ grep ' 404 ' access_log
+ sed -i -e /09/Apr/2017/d error_log.txt
sed: -e expression #1, char 5: unknown command: `A'


このように表示されます。
どのようにすれば考えていることを実現できますでしょうか。

よろしくお願いします。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 3

checkベストアンサー

+2

/09/Apr/2017/dのように、スラッシュ区切りの正規表現中に、テキストとして取るべきスラッシュが混入しているためにエラーとなっています。

区切り文字は別のものに変えられるので、\@$day@とすればいい…のですが、dコマンドは削除なので、やりたいことと正反対の動作になってしまいます。

sed -i -n -e "\\@$day@p" error_log.txtのように、-nで全行出力を止めて、pで目的の箇所だけ出力しましょう。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/04/10 21:21

    ご回答ありがとうございます。
    -nで止めてpで出力…
    何か難しいですね。と言うか自分が知識無さすぎですね(;^_^A
    試してみましたら本日分の行が全て消えました…
    何故でしょうか…

    キャンセル

  • 2017/04/10 21:24

    dateコマンドで「1 days ago」にしていたのを見落としていました、すみません(「昨日だけ残る」ことになります)。

    day=`date +'%d/%h/%Y'`とすれば今日の値が取れるので、そちらも書き換えてください。

    キャンセル

  • 2017/04/10 21:32

    ご回答ありがとうございます。

    なるほど、いけました!
    希望通り今日だけ残りました。
    ありがとうございます。
    今日以外を消すじゃなくて今日だけ残すって事なんですね。
    発想の転換と言うか考え方だけですね(;^_^A
    どちらにしても自分の力だけでは絶対に実現できませんでした。
    この度はありがとうございました。

    キャンセル

+1

+ sed -i -e /09/Apr/2017/d error_log.txt

スラッシュ多すぎですよね。エスケープしときましょう。

day=`date +'%d\/%h\/%Y' --date "1 days ago"`

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/04/10 21:21 編集

    ご回答ありがとうございます。
    お教え頂いた通りに変更しましたら希望通りになりました。
    贅沢を言えば本日以外すべて削除したいのですが、簡単にできるのでしょうか?
    自分の知識ではday=`date +'%d\/%h\/%Y' --date "1 days ago"`の数値を増やして並べる位しか思いつきませんが…

    キャンセル

+1

LANG=C
day=`date +'%d/%h/%Y'`

grep "$day.* 404 " access_log > error_log.txt


でいいのでは?

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/04/10 22:47 編集

    ご回答ありがとうございます。

    すごいシンプルですね!
    sedじゃないといけないと勝手に決め込んでいましたが
    grepで抜き出して書き出すと云う方法もあるんですね。
    勉強になりました。
    もっとしっかり学習します(;^_^A
    ありがとうございます。

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.33%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

同じタグがついた質問を見る

  • シェル

    257questions

    シェル(shell)はUnix や Linux 系のOSで使用されるコマンドインタプリタを指します。