Как передать значения из XML-файла в datagridviewtextbox в C#?
Допустим, я получил некоторый XML-файл, который выглядит так:
<NewDataSet>
<Table1 id = "one">
<Server>Server1</Server>
<Database>Database1</Database>
</Table1>
<Table1 id = "two">
<Server>Server2</Server>
<Database>Database2</Database>
</Table1>
</NewDataSet>
что я хочу сделать, это то, что я хочу прочитать значения из этого XML и положить их в datagridview
в разных колонках. Например: показать Database1
а также Database2
в одном столбце. Я использую Xpath для получения значений из XML-файла, вот мой код:
private void xmlGetValues()
{
XPathDocument doc = new XPathDocument("C:\\XMLfile1.xml");
XPathNavigator nav = doc.CreateNavigator();
XPathExpression expr;
expr = nav.Compile("/NewDataSet/Table1/Database");
XPathNodeIterator iterator = nav.Select(expr);
try
{
while (iterator.MoveNext())
{
XPathNavigator nav2 = iterator.Current.Clone();
}
}
catch (Exception exp)
{
MessageBox.Show(exp.Message);
}
}
это даст мне все значения от Database
теги и я не могу понять, как дать эти значения datagridviewtextbox
показать в моем datagridview
, Кто-нибудь может мне с этим помочь? (PS извините за мой плохой английский)
1 ответ
Решение
Пытаться,
XElement root = XElement.Load(file);
var tables = root.Descendants("Table1")
.Select(t => new
{
Server = t.Element("Server").Value,
Database = t.Element("Database").Value
});
foreach(var table in tables)
grid.Rows.Add(new object[] { table.Server, table.Database });