получить данные из DataTable с помощью LINQ - PullRequest
0 голосов
/ 13 мая 2011

У меня есть таблица данных, и я хочу напечатать содержимое таблицы на консоль.

System.Data.DataTable dt = new System.Data.DataTable();
dt.Columns.Add("FName");
dt.Columns.Add("LName");

DataRow dr;
dr = dt.NewRow();
dr["FName"] = "FName1";
dr["LName"] = "LName1";
dt.Rows.Add(dr);


dr = dt.NewRow();
dr["FName"] = "FName2";
dr["LName"] = "LName2";
dt.Rows.Add(dr);

dr = dt.NewRow();
dr["FName"] = "FName3";
dr["LName"] = "LName3";
dt.Rows.Add(dr);

Я хочу вывод на консоль следующим образом:

Row 1: FNAme = Fname1, LName = LName1
Row 2: FNAme = Fname2, LName = LName2
Row 2: FNAme = Fname3, LName = LName3

Как я могу сделать это с помощью LINQ?

Ответы [ 4 ]

4 голосов
/ 13 мая 2011

Это не имеет ничего общего с LINQ, вам нужно будет перебирать элементы.

StringBuilder sb = new StringBuilder();
foreach (DataRow dr in DataTable.Rows)
{
    sb.Append(String.Format("Row {0}: FNAme = {1}, LName = {2}", dt.Rows.IndexOf(row) + 1, dr["FName"], dr["LName"]));
}
3 голосов
/ 13 мая 2011

Это не совсем цель LINQ, но если вы действительно хотите ...

dt.Rows.Cast<DataRow>()
  .Select((DataRow dr, int i) =>
    {
      return String.Format("Row {0}: FNAme = {1}, LName = {2}", i, dr["FName"], dr["LName"]);
    })
  .All((line) =>
    {
      Console.WriteLine(line);
      return true;
    });
3 голосов
/ 13 мая 2011

Таким образом, вы можете использовать LINQ и написать что-то вроде этого

DataTable.Rows.ToList().ForEach(r => Console.WriteLine(String.Format("Row {0}: FNAme = {1}, LName = {2}", dr.Rows.IndexOf(r) + 1, r.Item["FName"], r.Item["LName"])

Но для того, что вы делаете, цикл foreach имеет больше смысла

//Borrowing Dustin Lanes foreach here.

StringBuilder sb = new StringBuilder();
foreach (DataRow dr in DataTable.Rows)
{
    sb.Append(String.Format("Row {0}: FNAme = {1}, LName = {2}", dt.Rows.IndexOf(row) + 1, dr["FName"], dr["LName"]));
}

Причина, по которой яскажем, что цикл foreach имеет больше смысла в том, что он понятнее того, что вы делаете.Реализация проще.

LINQ великолепен, но я стараюсь использовать его только тогда, когда он дает более четкое представление о том, что я делаю.Честно говоря, он становится де-факто ответом на все, что связано с любым кодом, связанным с коллекциями, и иногда это не ответ.

1 голос
/ 13 мая 2011

Более общее решение (также с использованием некоторого LINQ, поскольку у вас, похоже, есть все для этого; -))

DataTable dt = ...;

string formatStr = String.Join(", ", Enumerable.Range(0, dt.Columns.Count)
    .Select(c => dt.Columns[c].ColumnName + " = {" + c + "}").ToArray());

for (int i = 0; i < dt.Rows.Count; i++)
    Console.WriteLine("Row " + i + ": " + String.Format(formatStr, dt.Rows[i].ItemArray));
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...