読者です 読者をやめる 読者になる 読者になる

プログラマーな日々

プログラマー兼SEです。好きな習慣:TDD、好きなツール:WorkFlowy、好きな言語:C#、好きなAWSのサービス:Data Pipeline。趣味は開発環境を改善することです。

DataTableがNullまたは空かどうかを判定する拡張メソッドを定義する

.NET 拡張メソッド

DataTableがNullまたは空かどうかを判定する拡張メソッドを定義します。DataRowを保持していない場合に空と判断しています。
System.ComponentModel.IListSourceを実装したインスタンスであれば、DataTable以外でも使えます。

Extensions.cs

using System.ComponentModel;

namespace Extensions {
    public static class SystemComponentModelExtensions {
        /// <summary>
        /// 指定されたインスタンスがNullまたは要素数が0かどうかを示す値を取得します。
        /// </summary>
        /// <param name="self">IListSourceのインスタンス。</param>
        /// <returns>Nullまたは要素数が0の場合はtrue。それ以外の場合はfalse。</returns>
        public static bool IsNullOrEmpty(this IListSource self) {
            return (self == null) || (self.GetList().Count == 0);
        }
    }
}

Program.cs

using System;
using System.Data;
using Extensions;

namespace ConsoleApplication {
    class Program {
        static void Main(string[] args) {
            // Null
            DataTable dt = null;
            Console.WriteLine(dt.IsNullOrEmpty());

            // 行なし
            dt = new DataTable();
            dt.Columns.Add("col1", typeof(string));
            dt.Columns.Add("col2", typeof(string));
            dt.Columns.Add("col3", typeof(string));
            Console.WriteLine(dt.IsNullOrEmpty());

            // 行あり
            dt.Rows.Add("a", "b", "c");
            Console.WriteLine(dt.IsNullOrEmpty());

            Console.ReadLine();
        }
    }
}

実行結果