我正在尝试将我的对象放入DataTable中,以将其用作DataGrid的ItemsSource。
foreach (Translate t in item.Translations)
{
if (rowArray[t.IdSprache] == null)
{
rowArray[t.IdSprache] = t; //here I add the Translate objects to the object[]
}
}
dt.Rows.Add(rowArray); //adding the object[] to the DataTable
var test = dt.Rows[cnt].ItemArray[1] as Translate; //aaaaaaaaaaaaaaand the object is gone (test is always null)
cnt++;
}
一切正常,但是如果我想将DataRow的元素转换回Translate-Objects,我总是得到null
。
如果我查看行ItemArray
,我只会将对象视为字符串(Assembly.Type
)而不是Translate
个对象。
有人知道解决方法/解决方案吗?
答案 0 :(得分:1)
尝试使用DataSet
上的内置函数来创建架构和行。类似的东西:
Translate t1 = new Translate() { IdSprache = 0 };
Translate t2 = new Translate() { IdSprache = 3 };
Translate t3 = new Translate() { IdSprache = 7 };
DataTable dt = new DataTable();
for (int i = 0; i < 10; i++)
dt.Columns.Add(new DataColumn("C" + i, typeof(Translate)));
for (int i = 0; i < 5; i++)
{
DataRow dr = dt.NewRow();
dr[i] = new Translate() { IdSprache = i };
dt.Rows.Add(dr);
}
for (int i = 0; i < 5; i++)
{
for (int j = 0; j < 5; j++)
{
if (dt.Rows[i][j] as Translate != null)
Console.Write("T");
else
Console.Write("N");
}
Console.WriteLine();
}
打印
TNNNN
NTNNN
NNTNN
NNNTN
NNNNT