C# と VB.NET の質問掲示板
ASP.NET、C++/CLI、Java 何でもどうぞ
掲示板トップ
C# と VB.NET 入門
新規作成
利用方法
ツリー表示
トピック表示
ランキング
記事検索
過去ログ
ログ内検索
キーワードを複数指定する場合は 半角スペース で区切ってください。
検索条件は、(AND)=[A かつ B] (OR)=[A または B] となっています。
[返信]をクリックすると返信ページへ移動します。
キーワード
/
検索条件
/
(AND)
(OR)
検索範囲
/
(現在のログ)
(全過去ログ)
(過去ログ1)
(過去ログ2)
(過去ログ3)
(過去ログ4)
(過去ログ5)
(過去ログ6)
(過去ログ7)
(過去ログ8)
(過去ログ9)
(過去ログ10)
(過去ログ11)
(過去ログ12)
(過去ログ13)
(過去ログ14)
(過去ログ15)
(過去ログ16)
(過去ログ17)
(過去ログ18)
(過去ログ19)
(過去ログ20)
(過去ログ21)
(過去ログ22)
(過去ログ23)
(過去ログ24)
(過去ログ25)
(過去ログ26)
(過去ログ27)
(過去ログ28)
(過去ログ29)
(過去ログ30)
(過去ログ31)
(過去ログ32)
(過去ログ33)
(過去ログ34)
(過去ログ35)
(過去ログ36)
(過去ログ37)
(過去ログ38)
(過去ログ39)
(過去ログ40)
(過去ログ41)
(過去ログ42)
(過去ログ43)
(過去ログ44)
(過去ログ45)
(過去ログ46)
(過去ログ47)
(過去ログ48)
(過去ログ49)
(過去ログ50)
(過去ログ51)
(過去ログ52)
(過去ログ53)
(過去ログ54)
(過去ログ55)
(過去ログ56)
(過去ログ57)
(過去ログ58)
(過去ログ59)
(過去ログ60)
(過去ログ61)
(過去ログ62)
(過去ログ63)
(過去ログ64)
(過去ログ65)
(過去ログ66)
(過去ログ67)
(過去ログ68)
(過去ログ69)
(過去ログ70)
(過去ログ71)
(過去ログ72)
(過去ログ73)
(過去ログ74)
(過去ログ75)
(過去ログ76)
(過去ログ77)
(過去ログ78)
(過去ログ79)
(過去ログ80)
(過去ログ81)
(過去ログ82)
(過去ログ83)
(過去ログ84)
(過去ログ85)
(過去ログ86)
(過去ログ87)
(過去ログ88)
(過去ログ89)
(過去ログ90)
(過去ログ91)
(過去ログ92)
(過去ログ93)
(過去ログ94)
(過去ログ95)
(過去ログ96)
(過去ログ97)
(過去ログ98)
(過去ログ99)
(過去ログ100)
(過去ログ101)
(過去ログ102)
(過去ログ103)
(過去ログ104)
(過去ログ105)
(過去ログ106)
(過去ログ107)
(過去ログ108)
(過去ログ109)
(過去ログ110)
(過去ログ111)
(過去ログ112)
(過去ログ113)
(過去ログ114)
(過去ログ115)
(過去ログ116)
(過去ログ117)
(過去ログ118)
(過去ログ119)
(過去ログ120)
(過去ログ121)
(過去ログ122)
(過去ログ123)
(過去ログ124)
(過去ログ125)
(過去ログ126)
(過去ログ127)
(過去ログ128)
(過去ログ129)
(過去ログ130)
(過去ログ131)
(過去ログ132)
(過去ログ133)
(過去ログ134)
(過去ログ135)
(過去ログ136)
(過去ログ137)
(過去ログ138)
(過去ログ139)
(過去ログ140)
(過去ログ141)
(過去ログ142)
(過去ログ143)
(過去ログ144)
(過去ログ145)
(過去ログ146)
(過去ログ147)
(過去ログ148)
(過去ログ149)
(過去ログ150)
(過去ログ151)
(過去ログ152)
(過去ログ153)
(過去ログ154)
(過去ログ155)
(過去ログ156)
(過去ログ157)
(過去ログ158)
(過去ログ159)
(過去ログ160)
(過去ログ161)
(過去ログ162)
(過去ログ163)
(過去ログ164)
(過去ログ165)
(過去ログ166)
(過去ログ167)
(過去ログ168)
(過去ログ169)
(過去ログ170)
(過去ログ171)
(過去ログ172)
(過去ログ173)
(過去ログ174)
(過去ログ175)
(過去ログ176)
(過去ログ177)
(過去ログ178)
(過去ログ179)
強調表示
/
ON
(自動リンクOFF)
結果表示件数
/
20件
30件
40件
50件
100件
記事No検索
/
ON
大文字と小文字を区別する
No.30519 の関連記事表示
ヒット / 6件
(1-6 を表示)
<<
0
>>
■30519
Logファイルの解析について
□投稿者/ マサル -
(2008/12/25(Thu) 15:46:11)
分類:[.NET 全般]
こんにちわ。
現在、ログファイルを解析し、その最新情報を表示するソフトを作成しております。
ログファイルはlog4netではき出したテキストみたいなのを思って貰えればいいと思います。
上から順に古く、下に追記していくので下にあるものが新しいです。
流れ的には
・別アプリがログを随時更新している→自アプリで10秒ごとにそのログを読み込み、項目ごとに最新の内容だけを表示する
という繰り返しになります。
レベル/項目/内容
INFO 告知事項A [○○○○○○○]が発生しました
INFO 告知事項B [×××××××××]が発生しました
INFO 告知事項A [□□□□□□□□]が発生しました
ERROR 緊急事項A [○○○○○○○]が発生しました
INFO 告知事項B [○○○○○○○]が発生しました
ERROR 緊急事項A [○○○○○○○]が発生しました
それで、この中からINFOのみを抽出し、且つその項目ごとに最新の情報の[]内のみを表示するというのが作りたい物です。
例えば上のログの場合、望む結果は
告知事項A :□□□□□□□□
告知事項B:○○○○○○○
です。
INFOのみを抽出するのは、ヘッダ部というかその行頭に「INFO」という文字列が含まれているかどうか見ればいいだけなのでいいんですが
後はその最新だけ取得する方法です。
いくつか手法は考えたんですが、効率的な方法ではないような気がしています。
例えば告知事項分の変数なりを作っておき、上から順に読んでいってマッチすれば上書きしていくという物です。
全行読み終わるまでループ{
if(”告知事項A” という文字列が取得した行に含まれていたら){
strKokutiA = その行から[]に囲まれた部分だけを切り取って代入
}
if(”告知事項B” という文字列が取得した行に含まれていたら){
strKokutiB = その行から[]に囲まれた部分だけを切り取って代入
}
}
というような感じです。
上から順に全て読み取っていけば、最終的に変数strKokutiAとBには、一番新しい内容が上書き上書きで入っているという考え方です。
ログの方も随時更新されていますし、ログが小さい分には別にたいした処理でもないのでいいんですが
ログが大きくなると、10秒ごとにそのでかいファイルを読み込んで、上から全部1行ずつチェックして
というのを繰り返すことになるので、もっと効率良く処理出来ないものかと悩んでいます。
親記事 /過去ログ54より /
関連記事表示
削除チェック/
■30521
Re[1]: Logファイルの解析について
□投稿者/ .SHO -
(2008/12/25(Thu) 15:54:53)
■
No30519
(マサル さん) に返信
Seek すればいいのでは?
記事No.30519 のレス /過去ログ54より /
関連記事表示
削除チェック/
■30522
Re[2]: Logファイルの解析について
□投稿者/ .SHO -
(2008/12/25(Thu) 16:05:38)
> ■
No30519
(マサル さん) に返信
っていうか、常駐したまま10秒に1回見るなら、ファイルをクローズせずに
行が追加されるまでEOFを検知してれば、何もしなくていいような。
記事No.30519 のレス /過去ログ54より /
関連記事表示
削除チェック/
■30524
Re[3]: Logファイルの解析について
□投稿者/ マサル -
(2008/12/25(Thu) 17:14:18)
■
No30522
(.SHO さん) に返信
>>■
No30519
(マサル さん) に返信
>
> っていうか、常駐したまま10秒に1回見るなら、ファイルをクローズせずに
> 行が追加されるまでEOFを検知してれば、何もしなくていいような。
すいません、ちょっと具体的にどうなのかがわからないんですが
closeせずに開きっぱなしで、更に常時別アプリからの書き込みを検知するって事なんでしょうか?
まず既に別アプリが生成してあるログファイルを読み込んで、その時点での最終行までいきますよね?
そこでファイルを閉じずに、そのままstreamを放置しておくって事でしょうか?
その開いたままの状態で、また別アプリがログを追記した場合
自アプリで開いてる方には反映されるんですかね?
記事No.30519 のレス /過去ログ54より /
関連記事表示
削除チェック/
■30525
Re[4]: Logファイルの解析について
□投稿者/ .SHO -
(2008/12/25(Thu) 17:17:40)
■
No30524
(マサル さん) に返信
> 自アプリで開いてる方には反映されるんですかね?
やってみればいい。
記事No.30519 のレス /過去ログ54より /
関連記事表示
削除チェック/
■30526
Re[4]: Logファイルの解析について
□投稿者/ Jitta -
(2008/12/25(Thu) 18:24:42)
■
No30524
(マサル さん) に返信
> ■
No30522
(.SHO さん) に返信
> >>■
No30519
(マサル さん) に返信
>>
>>っていうか、常駐したまま10秒に1回見るなら、ファイルをクローズせずに
>>行が追加されるまでEOFを検知してれば、何もしなくていいような。
> すいません、ちょっと具体的にどうなのかがわからないんですが
> closeせずに開きっぱなしで、更に常時別アプリからの書き込みを検知するって事なんでしょうか?
>
> まず既に別アプリが生成してあるログファイルを読み込んで、その時点での最終行までいきますよね?
> そこでファイルを閉じずに、そのままstreamを放置しておくって事でしょうか?
> その開いたままの状態で、また別アプリがログを追記した場合
> 自アプリで開いてる方には反映されるんですかね?
seek に、終わりまで飛ぶってのがあるので、それを利用する。
書く方は、読み取り共有で書き込む。書いたら閉じる。このとき、バッファリングの途中で書き出さないように設定する(って、そんな設定あったっけ?)。
読む方は、開いたまま。現在位置からファイルの最後までを読み取って、その中から検索する。
記事No.30519 のレス /過去ログ54より /
関連記事表示
削除チェック/
<<
0
>>
パスワード/
-
Child Tree
-