0

可能重复:
仅显示数据网格中的根节点

        this.dataGrid1 = new System.Windows.Forms.DataGrid();
        this.dataGrid1.DataMember = "";
        this.dataGrid1.Location = new System.Drawing.Point(36, 50);
        this.dataGrid1.Name = "dataGrid1";
        this.dataGrid1.Size = new System.Drawing.Size(464, 432);
        this.dataGrid1.TabIndex = 0;
        // 
        this.AutoScaleBaseSize = new System.Drawing.Size(35, 13);
        this.ClientSize = new System.Drawing.Size(592, 573);
        this.Controls.AddRange(new System.Windows.Forms.Control[] { this.dataGrid1 });
        ((System.ComponentModel.ISupportInitialize)(this.dataGrid1)).EndInit();
        this.ResumeLayout(false);


        XmlDataDocument xmlDatadoc = new XmlDataDocument();
        xmlDatadoc.DataSet.ReadXml("abcd.xml");

        DataSet ds = new DataSet("abc");
        ds = xmlDatadoc.DataSet;

        dataGrid1.DataSource = ds.Tables[0];

上面的代码读取 XML 文件并显示在 DataGrid 中。有人可以告诉我如何编辑 DataGrid 以便可以编辑 XML 中的相应值吗?

4

2 回答 2

0

要将更改从DataSet后面保存到 XML 文件,您只需要做

     ds.Tables[0] = (DataTable)(dataGrid1.DataSource);
     ds.WriteXml("your path here");

作为旁注,您的代码有点多余。当您创建 的实例时XmlDataDocument,您可以只访问它的DataSet属性而无需创建新DataSet实例,如代码所示。如果您只想将 XML 文件读入 aDataSet您可以执行以下操作

    DataSet ds = new DataSet("abc");
    ds.ReadXml("abcd.xml");

    dataGrid1.DataSource = ds.Tables[0];
于 2012-10-11T06:03:35.910 回答
0

XML 和 Datagrid Dataset 没有相互关联,因此您需要通过从 Dataset 编写 XML 来手动完成。

于 2012-10-11T05:15:22.950 回答