基于xmlElement编辑xml节点

Ham*_*reb 5 c# xml asp.net

我尝试了两种方法,但它们都没有工作..第一种方式::

string filepath = Server.MapPath[this is not a link]("XMLFile2.xml");
XmlDocument xdoc = new XmlDocument();
                xdoc.Load(filepath);

                XmlNode root = xdoc.DocumentElement;
                XmlNode idNode = root.SelectSingleNode("/students/student/id");
if (idNode.Value == 9.ToString())
                    {
                        var nodeOfStudent = xdoc.SelectNodes("/students/student[@id='9']");
                        nodeOfStudent[1].InnerXml = TextBox_firstname.Text;
                        nodeOfStudent[2].InnerXml = TextBox_lastname.Text;
                        nodeOfStudent[3].InnerXml = TextBox_dob.Text;
                        nodeOfStudent[4].InnerXml = TextBox_class.Text;
                        nodeOfStudent[5].InnerXml = TextBox_section.Text;
                        nodeOfStudent[6].InnerXml = TextBox_telephone.Text;

                    }
Run Code Online (Sandbox Code Playgroud)

第二种方式::

string filepath = Server.MapPath("XMLFile2.xml");
                XmlDocument xdoc = new XmlDocument();
                xdoc.Load(filepath);

                XmlNode root = xdoc.DocumentElement;
                XmlNode idNode = root.SelectSingleNode("/students/student/id");

xdoc.SelectSingleNode("/students/student[@id='10']/firstname").InnerXml = TextBox_firstname.Text;
                        xdoc.DocumentElement.AppendChild(firstname);
                        xdoc.SelectSingleNode("/students/student[@id='10']/lastname").InnerXml = TextBox_firstname.Text;
                        xdoc.SelectSingleNode("/students/student[@id='10']/dob").InnerXml = TextBox_firstname.Text;
                        xdoc.SelectSingleNode("/students/student[@id='10']/class").InnerXml = TextBox_firstname.Text;
                        xdoc.SelectSingleNode("/students/student[@id='10']/section").InnerXml = TextBox_firstname.Text;
                        xdoc.SelectSingleNode("/students/student[@id='10']/telephone").InnerXml = TextBox_firstname.Text;

                        xdoc.Save(filepath);
Run Code Online (Sandbox Code Playgroud)

有什么不对的我没看到...我的xml文件看起来像这样::

<students>
  <student>
    <id>1</id>
    <first_name>ahmad</first_name>
    <last_name>hani</last_name>
    <DOB>12/5/1998</DOB>
    <class>sixth</class>
    <section>A</section>
    <telephone>06555632</telephone>
  </student>  
</students>
Run Code Online (Sandbox Code Playgroud)

我使用查询字符串从使用"QueryString"的另一个页面中的gridView加载值....

提前致谢.

Ser*_*kiy 1

您可以使用 Linq to xml 轻松完成此操作:

int id = 9;
XDocument xdoc = XDocument.Load(filepath);
var student = xdoc.Descendants("student")
                  .Where(s => (int)s.Element("id") == id)
                  .SingleOrDefault();

if (student != null)
{
    student.Element("first_name").Value = TextBox_firstname.Text;
    student.Element("last_name").Value = TextBox_lastname.Text;
    student.Element("DOB").Value = TextBox_dob.Text;
    student.Element("class").Value = TextBox_class.Text;
    // etc
}

xdoc.Save(filepath);
Run Code Online (Sandbox Code Playgroud)