如何使用xml中的数据加载datagridview

时间:2013-08-07 21:57:50

标签: c# xml datagridview datatable dataset

我有这个XML:

<container_1 attr1="..." attr2="..." attr3="...">
  <rekord_1>
    <type_1 attr1="..." attr2="..." ... />
    <type_2 attr1="..." attr2="..." ... /> 
  </rekord_1>
  <rekord_2>... </rekord_2>
  .
  .
  <rekord_N> ... </rekord_N>
</container_1>

我可以解析我想要的方式并在控制台应用程序中显示它(使用XMLElementsXMLNodeLists和几个循环)但我想创建一个带GUI和表视图的应用程序。 我的表单应用程序可以读取XML,但它现在只能处理1个标记。例如,如果我得到container_1标记,它只会输出container_1的属性,但我想在表视图中的container_1下显示记录。

我想让它像我在控制台中的旧程序一样可以查看。

如何从XML中获取数据,以便我能够使用元素/属性?因为我想在表格视图中设置它们的位置。 我应该阅读哪些文件?或者是否有一些可能对我有用的例子?

编辑(aug.20): 以下是代码的主要部分:

private void button1_Click(object sender, EventArgs e)
    {
        Stream input=null;
        OpenFileDialog dialog = new OpenFileDialog();
        openFileDialog1.InitialDirectory = "C:/";
        openFileDialog1.Filter = "xml file | *.xml";
        openFileDialog1.FilterIndex = 2;
        openFileDialog1.RestoreDirectory = true;

        if (openFileDialog1.ShowDialog() == DialogResult.OK) {
            try
            {
                if ((input = openFileDialog1.OpenFile()) != null)
                {
                    using (input)
                    {
                        XmlReader xmlFile = XmlReader.Create(input, new XmlReaderSettings());
                        DataSet dataSet = new DataSet();
                        dataSet.ReadXml(xmlFile);
                        DataSet containers = new DataSet();
                        dataGridView1.DataSource = dataSet.Tables[tag];
                        xmlFile.Close();
                    }
                }
            }
            catch (Exception ex) {
                MessageBox.Show("ERROR");
            }
        }
    }

如果我的标签是容器或rekord并且进行此输出,则此函数可以很好地显示: outputs

但我无法显示container1 +它的rekords,container2 +它的rekords等等,只能同时显示所有容器或所有rekords。

1 个答案:

答案 0 :(得分:0)

听起来你想要做的就是将XML拉入数据集,然后将该DataSet提供给Gridview。

看起来有人已经在Stack Exchange上问过这个问题了

Any way to populate items from xml to Datagridview using c#

<强>加成

您所拥有的是具有多个DataSet的{​​{1}}。 DataTables一次只能显示一个DataGridView

代码

DataTable

并将dataGridView1.DataSource = dataSet.Tables[tag]; 放入container_1,您将撤回DataSet的tag TABLE

我建议您查看DataGridViewDataSetDataTable的MSDN,看看这是否真的适合您。

或许也可以查看C# DataGridView Tutorial

它不会受到伤害。