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

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

ただいまの
回答率

90.76%

  • C#

    6565questions

    C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

C#でlogを出力する方法(log4net無しで)

解決済

回答 5

投稿

  • 評価
  • クリップ 3
  • VIEW 42K+

hurikake_dx

score 10

デバッグとして変数をlogに出力したいのですが検索するとlog4netを使用する例が多く出てきます。
チーム制作中なのでdllを追加する等はあまりやりたくないです、、、
.txt形式ですぐに確認できる形で出力できる方法(関数)を教えてください。
よろしくお願いします。
  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 5

+7

こんにちは

.NETの標準機能のTraceクラスなどを使う方法もありますが、
変数の中身がただの文字や数値なのなら、単純にテキストファイルに書いていくだけでは駄目なのでしょうか?

string appendText = DateTime.Now.ToString("yyyy/MM/dd HH:mm:ss") + " value " + Environment.NewLine;
System.IO.File.AppendAllText("C:\log.txt", appendText);
コード

意図と違っていたらすみません。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2015/02/13 10:08

    こんな簡単に出力できるんですね…!
    テキストファイルに書き出すだけでいいのでこのコードで大丈夫です。
    ありがとうございました!

    キャンセル

checkベストアンサー

+1

どうしてもファイルで出力したいなら、こういう次元でいいのでは?
どうせ細かい動作なんて、決め打ちでいいわけですし。

エントリポイント
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using System.Windows.Forms;

namespace WindowsFormsApplication3
{
    static class Program
    {
        /// <summary>
        /// アプリケーションのメイン エントリ ポイントです。
        /// </summary>
        [STAThread]
        static void Main()
        {
#if DEBUG
            AppLog.Start();
#endif
            Application.EnableVisualStyles();
            Application.SetCompatibleTextRenderingDefault(false);
            Application.Run(new Form1());

#if DEBUG
            AppLog.Close();
#endif
        }
    }
}

アプリケーション側
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Diagnostics;

namespace WindowsFormsApplication3
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        private void Form1_Load(object sender, EventArgs e)
        {
#if DEBUG
            AppLog.WriteLine("hoge");
#endif

        }
    }
}

ログクラス側
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace WindowsFormsApplication3
{
    /// <summary>
    /// アプリケーション独自デバッグ用ログクラス
    /// </summary>
    class AppLog
    {
        private static System.IO.StreamWriter _sw = null;

        /// <summary>
        /// ファイル書き出しを開始
        /// </summary>
        public static void Start()
        {
            AppLog._sw = new System.IO.StreamWriter(
                    System.IO.Path.GetDirectoryName(
                    System.Reflection.Assembly.GetExecutingAssembly().Location)+
                    System.IO.Path.DirectorySeparatorChar + "App.log", true);
        }

        /// <summary>
        /// ファイル書き出しを終了
        /// </summary>
        public static void Close()
        {
            AppLog._sw.Close();
        }

        /// <summary>
        /// 書き込み
        /// </summary>
        /// <param name="value">書き込む値</param>
        public static void WriteLine(object value)
        {
            // TODO もしだったら、型を調べて配列やリストの展開を行ったり
            _sw.WriteLine(value);
        }
    }
}

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2015/02/13 10:02

    長いソースまでつけていただきありがとうございます!
    助かりました!

    キャンセル

+1

普通にStreamWriterを使ったのではダメでしょうか?
public static void Log(string message,string EncodingName) {
    Encoding enc = Encoding.GetEncoding(EncodingName);
    string time = DateTime.Now.ToString("yyyy/MM/dd HH:mm:ss.ms");
    string str = string.Format("{0},{1}", time, message);
    StreamWriter writer = new StreamWriter(Path, true, enc);
    writer.WriteLine(str);
    writer.Flush();
    writer.Close();
}
例外処理など端折ってますが。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2015/02/13 10:11

    回答ありがとうございます!
    自分は検索してLog4Netを使う記事しか見つけられなかったので、StreamWriterというものがあることを知りませんでした…

    キャンセル

+1

変数の型によってはシリアル化もありかな?
型指定が面倒だけど型のほうにSaveメソッド的なものを乗っけておけばちょっとは楽?

下は2個1です。

        /// <summary>
        /// ファイルにシリアル化したテキストを書き込みます
        /// </summary>
        /// <typeparam name="T">オブジェクトの型</typeparam>
        /// <param name="obj">シリアル化するオブジェクト</param>
        /// <param name="writer">シリアル化したテキストを書き込むファイルパス</param>
        public static void SerializeToFile<T>(T obj, string path)
        {
            var setting = new XmlWriterSettings();
            setting.Encoding = new UTF8Encoding(false);
            setting.Indent = true;
            setting.NewLineHandling = NewLineHandling.Entitize;
            using (var xw = XmlTextWriter.Create(path, setting))
            {
                Serialize<T>(obj, xw);
            }
        }

        /// <summary>
        /// シリアル化します
        /// </summary>
        /// <typeparam name="T">オブジェクトの型</typeparam>
        /// <param name="obj">シリアル化するオブジェクト</param>
        /// <param name="writer">シリアル化したテキストを書き込むストリーム</param>
        public static void Serialize<T>(T obj, XmlWriter writer)
        {
            var serializer = new XmlSerializer(typeof(T));
            serializer.Serialize(writer, obj);
        }

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2015/02/06 20:33

    自分用に使ってるやつを貼り付けましたので、XmlWriterの設定はご自由に変更ください。

    キャンセル

  • 2015/02/06 20:39

    回答つけてからなんですが、そもそもリリースビルドでやりたいのか(Debug.Printじゃだめのか)って問題がありましたね;

    キャンセル

  • 2015/02/13 10:07

    質問が分かりにくかったですね…すみません
    入力されている物の平均を取りたかったので(例えるならサイコロの出た目を記録しておく感じで)中身が取り出せれば何でもよかったのです。
    C#は最近始めたのでどんな機能があるかもさっぱりわからず(Debug.Printとか)この様な質問になってしまいました。
    回答ありがとうございました!

    キャンセル

0

思うところがあるのと、知識の共有をいつの日かしたいと思っていたので、コメントしておきます。
まずは、お目汚しの回答を行ってしまい、申し訳ございません。

 意見(このコメントにおける結論)

log4netを利用する利点が少ないまたは必須ではない場合は、
.NET Frameworkが提供するログ機構を使用されることを推奨します。

 .NET Frameworkが提供するログ出力機構について

私が認識している主な機能としては以下の通りです。

  • 2種類あり、DebugとTraceがあります。
    リリース(Release)ビルドとデバッグ(Debug)ビルドでログ出力を無効にすることができます。
    リリース時はTraceのみログ出力され、Debugのログ出力は行われません。
    DebugとTraceによってログの出力先を変更することができます。
    使い分けとしては出力頻度と重要度で切り替えます。(出力頻度が高いものはデバッグ時のみ必要であることが多い)
  • Staticクラスのため、事前に各クラスに仕込む必要がない
  • イベントログ・コンソール・ファイルへ出力することができる
  • TraceについてはInformation/Warning/Errorを切り替えることができ、設定で出力レベルを変更することができる
  • ファイル出力については、日付ごと、ファイルサイズでのローテート(ファイルの切り替え)が可能

★気が向いたらapp.configの設定を挿入する、気が向いたらファイルやRollingFile~を記載する★

注意点としては、リリースビルド時に実行されるものと、実行されないものが出てしまうことを覚えておいてください。

//例1
var log = string.Format("i={0}", i); //リリース時実行される
Debug.WriteLine(log); //リリース時実行されない
//例2
Debug.WriteLine("increment i={0}", i++); //リリース時実行されない

 log4netが提供するログ出力機構について

log4netを使う利点は以下の通りだと認識しています。

  • クラスごとに出力を制御できる
  • DBへログ出力できる
  • nuGetで簡単にDLLを内包できる
  • ログあふれの制御が可能

ただし、以下の点で利便性が低いことも認識しています。

  • 各クラスにlog4netの呼び出しが必要(定型文)

※XMLの設定やAssemblyInfoへの組み込みについては一度やってしまえば何もしなくてよいので、利便性が低いとは考えていません

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

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

関連した質問

  • 受付中

    linux の module availlistの出力をファイルに落とす

    linux の module availlistの出力をファイルに落とす にはどうしたらいいのでしょうか。 %UNIX> module availlist |& tee a.

  • 解決済

    AndroidAppでURL解析を行いたい!

    前提・実現したいこと AndroidAppでURLを解析したいです! 例) [https://www.google.co.jp/?q=android] =>q = andr

  • 解決済

    クエリログが出力されない

    実現したいこと 以下の環境でクエリログを出力したいと思っております。 Centos 5.5 MySql 5.1.73 試したことに記載さした手順で設定を行ってみましたがログ

  • 解決済

    mysqldumpでslow-log

    毎日mysqldumpでDBのバックアップを取っているのですが、バックアップ処理で投げられるSelect文がslow-logに記録されているようです。検討している方法は以下の2つ

  • 解決済

    PHP クラスのparameter

    PHPのクラスで各メソッド毎にファイルを作成してデータベースにアクセスし、そこから出力するという処理を行いたいんですが ⓵mysqli_query() expects at le

  • 受付中

    PHP AjaxでAPIアクセスして、JSONデータを取得する。

    テキストボックスにコードを入力してボタンが押されたら、別サーバのAPIにアクセスして、情報を取得するPGでつまづいています。 failの、「alert("ajaxでExcepti

  • 解決済

    ライブラリをビルドしたい。

    CLNというライブラリをビルドしたいのですがうまくいきません。 CLNによるとconfigureを実行すれば良いということだったので, MinGWでGCCとMSYSをダウンロー

  • 解決済

    Javascriptで要素が存在するかどうか知りたいです。

    前提・実現したいこと javascriptで取得したHTML要素があるかどうかを調べたいです。 発生している問題・エラーメッセージ Uncaught DOMExcepti

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

  • C#

    6565questions

    C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。