我有一个包含单行的DataTable。我想将此DataTable值转换为字符串数组,以便我可以通过字符串数组索引访问该DataTable的列值 例如,如果我的DataTable如下
| Name | Address | Age |
-------------------------------
| jim | USA | 23 |
我想将Datatable中的值存储到我的字符串数组中,以便 MyStringArray [1] 为我提供值USA。
先谢谢
答案 0 :(得分:25)
非常简单:
var stringArr = dataTable.Rows[0].ItemArray.Select(x => x.ToString()).ToArray();
其中DataRow.ItemArray
属性是一个对象数组,其中包含数据表的每列的行值。
答案 1 :(得分:5)
也许是这样的,假设数据表中有很多这些行,并且每行都是row
:
List<string[]> MyStringArrays = new List<string[]>();
foreach( var row in datatable.rows )//or similar
{
MyStringArrays.Add( new string[]{row.Name,row.Address,row.Age.ToString()} );
}
然后您可以访问一个:
MyStringArrays.ElementAt(0)[1]
如果你使用 linqpad ,这是你的例子的一个非常简单的场景:
class Datatable
{
public List<data> rows { get; set; }
public Datatable(){
rows = new List<data>();
}
}
class data
{
public string Name { get; set; }
public string Address { get; set; }
public int Age { get; set; }
}
void Main()
{
var datatable = new Datatable();
var r = new data();
r.Name = "Jim";
r.Address = "USA";
r.Age = 23;
datatable.rows.Add(r);
List<string[]> MyStringArrays = new List<string[]>();
foreach( var row in datatable.rows )//or similar
{
MyStringArrays.Add( new string[]{row.Name,row.Address,row.Age.ToString()} );
}
var s = MyStringArrays.ElementAt(0)[1];
Console.Write(s);//"USA"
}
答案 2 :(得分:4)
如果这就是您想要做的所有事情,则无需将其转换为数组。您只需访问:
string myData=yourDataTable.Rows[0][1].ToString();//Gives you USA
答案 3 :(得分:3)
string[] result = new string[table.Columns.Count];
DataRow dr = table.Rows[0];
for (int i = 0; i < dr.ItemArray.Length; i++)
{
result[i] = dr[i].ToString();
}
foreach (string str in result)
Console.WriteLine(str);
答案 4 :(得分:1)
如果您要使用 System.Data 而不是 System.LINQ ,则可以执行以下操作。
List<string> BrandsInDataTable = new List<string>();
DataTable g = Access._ME_G_BrandsInPop();
if (g.Rows.Count > 0)
{
for (int x = 0; x < g.Rows.Count; x++)
BrandsInDataTable.Add(g.Rows[x]["Name"].ToString());
}
else return;
答案 5 :(得分:0)
private string[] GetPrimaryKeysofTable(string TableName)
{
string stsqlCommand = "SELECT column_name FROM INFORMATION_SCHEMA.KEY_COLUMN_USAGE " +
"WHERE OBJECTPROPERTY(OBJECT_ID(constraint_name), 'IsPrimaryKey') = 1" +
"AND table_name = '" +TableName+ "'";
SqlCommand command = new SqlCommand(stsqlCommand, Connection);
SqlDataAdapter adapter = new SqlDataAdapter();
adapter.SelectCommand = command;
DataTable table = new DataTable();
table.Locale = System.Globalization.CultureInfo.InvariantCulture;
adapter.Fill(table);
string[] result = new string[table.Rows.Count];
int i = 0;
foreach (DataRow dr in table.Rows)
{
result[i++] = dr[0].ToString();
}
return result;
}