C#操作xml

获取

获取node


通过doc对象执行SelectSingleNode或SelectNodes来发生
demo:[在根节点下获取子节点]
    XmlDocument xmlDoc = new XmlDocument();//创建xml文件对象
    xmlDoc.Load(xmlName);//载入xml文件
    XmlNode root = xmlDoc.DocumentElement;//获取文件的根节点
    XmlNodeList xmlNodelist = root.SelectNodes("xmlChildNode");//获取符合该子节点名称的所有子节点,若没有,返回空
    XmlNode xmlNode = root.SelectSingleNode("xmlChildNode");//获取符合该子节点名称的第一个节点,若没有,返回空
    string node_text = xmlNode.InnerText;//若节点为叶子节点,则可通过此属性值获取叶子的包含值,若不是叶子节点,值为空

获取Attribute值


通过node对象获取Attributes集合来获取Attribute值
demo:
    XmlDocument xmlDoc = new XmlDocument();//创建xml文件对象
    xmlDoc.Load(xmlName);//载入xml文件
    XmlNode node = xmlDoc.DocumentElement;//获取需要查找的属性的所属节点
    XmlAttribute attr = node.Attributes["Name"];//获取需要查找的属性,若没有。返回空
    if(attr!=null)
        string attr_value = attr.Value;//获取属性值

添加

添加node


通过doc对象执行CreateElement来发生
对任何层级节点的子节点添加都可通过父节点执行AppendChild来添加,注意,任何节点只能在拥有子节点与拥有节点值中二选一,即只拥有子节点或者只拥有InnerText,一旦执行node.InnerText,该节点的所有子节点将被去除;
demo:[在根节点下创建新的子节点]
    XmlDocument xmlDoc = new XmlDocument();//创建xml文件对象
    xmlDoc.Load(xmlName);//载入xml文件
    XmlNode root = xmlDoc.DocumentElement;//获取文件的根节点
    XmlNode new_node = xmlDoc.CreateElement(newNode);//在文件对象中创建一个新的节点
    root.AppendChild(new_node);//将新建节点添加为root节点的子节点,即作为根节点的子节点
    xmlDoc.Save(xmlName);//保存xml

添加或修改Attribute


通过doc对象执行CreateAttribute来发生
    XmlDocument xmlDoc = new XmlDocument();//创建xml文件对象
    xmlDoc.Load(xmlName);//载入xml文件
    XmlAttribute new_attribute = xmlDoc.CreateAttribute("Name");//创建新的属性,属性名Name
    new_attribute.Value = "Jack"; //新属性属性值为Jack
    node.Attributes.SetNamedItem(new_attribute);//向node节点添加该属性
    xmlDoc.Save(xmlName);//保存xml

移除

移除node


通过node对象执行RemoveChild来发生
demo:[移除某子节点]
    mlDocument xmlDoc = new XmlDocument();//创建xml文件对象
    xmlDoc.Load(xmlName);//载入xml文件
    XmlNode node = xmlDoc.DocumentElement;//获取需要查找的属性的所属节点
    XmlNode xmlNode = node.SelectSingleNode("xmlChildNode");//获取符合某子节点名称的第一个节点,若没有,返回空
    node.RemoveChild(xmlNode);//移除该子节点及其所有子节点

移除Attribute


通过node对象获取Attributes集合并通过Remove或RemoveAt或RemoveNamedItem来发生
demo:[移除某属性]
    XmlDocument xmlDoc = new XmlDocument();//创建xml文件对象
    xmlDoc.Load(xmlName);//载入xml文件
    XmlNode node = xmlDoc.DocumentElement;//获取需要查找的属性的所属节点
    XmlAttribute attr = node.Attributes["Name"];//获取需要查找的属性,若没有。返回空
    node.Attributes.Remove(attr);//移除查找到的属性
    node.Attributes.RemoveAt(0);//移除第一个属性
    node.Attributes.RemoveNamedItem("Name");//移除Name属性
C# 读取 XML 文件有多种方法,以下为你详细介绍: ### 使用 `XmlDocument` 操作 `XmlDocument` 是一个用于处理 XML 数据的类,它可以将 XML 文件加载到内存中,并提供了一系列方法和属性来操作 XML 节点。示例代码如下: ```csharp using System; using System.Collections.Generic; using System.Xml; class Program { static void Main() { // 获取所有一级目录 List<string> devices = new List<string>(); XmlDocument doc = new XmlDocument(); doc.Load(AppDomain.CurrentDomain.BaseDirectory + @"\TEMP\Configs.xml"); XmlNode xnl1 = doc.DocumentElement; foreach (XmlNode xn1 in xnl1.ChildNodes) { XmlElement xe1 = (XmlElement)xn1; devices.Add(xe1.GetAttribute("name").ToString()); } // 获取某个一级目录下的子目录 List<string> types = new List<string>(); doc = new XmlDocument(); doc.Load(AppDomain.CurrentDomain.BaseDirectory + @"\TEMP\Configs.xml"); xnl1 = doc.DocumentElement; foreach (XmlNode xn1 in xnl1) { XmlElement xe1 = (XmlElement)xn1; if (xe1.GetAttribute("name").ToString() == "aaa") { XmlNodeList xnl2 = xe1.ChildNodes; foreach (XmlNode xn2 in xnl2) { XmlElement xe2 = (XmlElement)xn2; types.Add(xe2.GetAttribute("name").ToString()); } break; } } } } ``` ### 使用 `XmlTextReader`/`XmlTextWriter` 操作 `XmlTextReader` 用于读取 XML 文件,`XmlTextWriter` 用于写入 XML 文件。这种方式是基于流的方式,逐行读取 XML 文件,适合处理大型 XML 文件。示例代码如下: ```csharp using System; using System.Xml; class Program { static void Main() { using (XmlTextReader reader = new XmlTextReader("path/to/your/xml/file.xml")) { while (reader.Read()) { if (reader.NodeType == XmlNodeType.Element) { Console.WriteLine("Element: " + reader.Name); } } } } } ``` ### 使用 `Linq to Xml` 操作 `Linq to Xml` 是一种基于 LINQ 的 XML 处理方式,它提供了一种更简洁、更灵活的方式来处理 XML 数据。示例代码如下: ```csharp using System; using System.Linq; using System.Xml.Linq; class Program { static void Main() { XDocument doc = XDocument.Load("path/to/your/xml/file.xml"); var elements = from el in doc.Descendants("elementName") select el; foreach (var element in elements) { Console.WriteLine(element.Value); } } } ``` ### 使用 `DataSet` 操作 `DataSet` 可以将 XML 文件加载到内存中,并将其转换为表格形式,方便进行数据操作。这种方式最简单,而且取数据也很方便,但是对于比较复杂的 XML操作起来也很麻烦,每一个带属性的节点都会生成一个 table。示例代码如下: ```csharp using System; using System.Data; class Program { static void Main() { // xml 文件路径 string xmlPath = Application.StartupPath + "\\Student.xml"; // 不带属性 string xmlPaths = Application.StartupPath + "\\Students.xml"; // 带属性 // dataset 读取简单 xml 文件 DataSet ds = new DataSet(); ds.ReadXml(xmlPath); // 读取第一条数据的 name 节点 string name = ds.Tables[0].Rows[0]["name"].ToString(); Console.WriteLine(name); // dataset 读取带属性的 xml 文件 ds = new DataSet(); ds.ReadXml(xmlPaths); // 读取的节点名称 string nodeName = "name"; name = ds.Tables[nodeName].Rows[0][nodeName + "_Text"].ToString(); // 读取节点的 id 属性 string id = ds.Tables[nodeName].Rows[0]["id"].ToString(); Console.WriteLine("id:{0},name:{1}", id, name); } } ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值