假设我有一些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
中。谁能帮我这个? (P.S.抱歉我的英语不好)
答案 0 :(得分: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 });