C#を使用して既存のDataSetに列を挿入しようとしています。
例として、DataSetを次のように定義しています。
DataSet ds = new DataSet();
ds.Tables.Add(new DataTable());
ds.Tables[0].Columns.Add("column_1", typeof(string));
ds.Tables[0].Columns.Add("column_2", typeof(int));
ds.Tables[0].Columns.Add("column_4", typeof(string));
後のコードで、列2と列4の間に列を挿入したいと思います。
DataSetsには列を追加するためのメソッドがありますが、挿入するための最良の方法を見つけることができないようです。
次のようなものを書きたいのですが...
...Columns.InsertAfter("column_2", "column_3", typeof(string))
最終結果は、次の列を持つテーブルを持つデータセットになります。column_1 column_2 column_3 column_4
むしろ:column_1 column_2 column_4 column_3これはaddメソッドが私に与えるものです
確かにこのようなことをする方法があるはずです。
編集 ...以下のコメントに基づいて、DataSetで何をしているのかを明確にしたいだけです。
ストアドプロシージャからデータセットを取得しています。次に、データセットに列を追加して、Excelドキュメントに変換する必要があります。ストアドプロシージャから返されるデータを制御できないため、事後に列を追加する必要があります。
この目的のために DataColumn.SetOrdinal() メソッドを使用できます。
DataSet ds = new DataSet();
ds.Tables.Add(new DataTable());
ds.Tables[0].Columns.Add("column_1", typeof(string));
ds.Tables[0].Columns.Add("column_2", typeof(int));
ds.Tables[0].Columns.Add("column_4", typeof(string));
ds.Tables[0].Columns.Add("column_3", typeof(string));
//set column 3 to be before column 4
ds.Tables[0].Columns[3].SetOrdinal(2);
私はあなたの提案を使用して、DataSetのDataColumnCollectionの拡張メソッドを作成しました。
public static void InsertAfter(this DataColumnCollection columns,
DataColumn currentColumn, DataColumn newColumn)
{
if (!columns.Contains(currentColumn.ColumnName))
throw new ArgumentException(/** snip **/);
columns.Add(newColumn);
//add the new column after the current one
columns[newColumn.ColumnName].SetOrdinal(currentColumn.Ordinal + 1);
}
私は今書くことができます:
dt = ds.Tables[0];
dt.Columns.InsertAfter(dt.Columns["column_2"], new DataColumn("column_3"));
https://stackoverflow.com/a/17372008/492336 に基づいて、SetOrdinalとIndexOf()を使用してbar
をfoo
の前に挿入します。
table.Columns.Add("bar").SetOrdinal(table.Columns.IndexOf("foo"));
foo
の後に挿入するには、+1
を追加するだけです。
table.Columns.Add("bar").SetOrdinal(table.Columns.IndexOf("foo")+1);