c#操作xml文件之二

上一帖我们已经对xpath语法进行了简单的介绍,对xml文件的和操作数据库有一些相同之处,同样是增,删,改,查四种操作。现在我们就详细介绍一下增和删两种操作。看下面的一个xml示例:
 

<? xml version="1.0" encoding="utf-8" ?>
< phonebook >
  
< member  id ="6" >
    
< name > 456 </ name >
    
< qq > 5465 </ qq >
  
</ member >
  
< member  id ="5" >
    
< name > jjjjj </ name >
    
< qq > 3456789 </ qq >
  
</ member >
</ phonebook >


  xml的每个节点分为节点名称,节点值和属性三类,如:member节点:id为其一个属性,menber为其节点名称。再如:name节点456为其节点值。
如果我们需要增加一个节点可以调用一下几个方法:
 

  ///  < summary >
        /// 在根节点下添加父节点
        /// 
</ summary >
        public static void AddParentNode(string xmlPath,string parentNode)
        {
            XmlDocument xdoc = new XmlDocument();
            xdoc.Load(xmlPath);
            // 创建一个新的menber节点并将它添加到根节点下
            XmlElement Node = xdoc.CreateElement(parentNode);
            xdoc.DocumentElement.PrependChild(Node);
            xdoc.Save(xmlPath);
        }

    #region 插入一节点,带一属性
        /// 
< summary >
        /// 插入一节点,带一属性
        /// 
</ summary >
        /// 
< param  name ="xmlPath" > Xml文档路径 </ param >
        /// 
< param  name ="MainNode" > 当前节点路径 </ param >
        /// 
< param  name ="Element" > 新节点 </ param >
        /// 
< param  name ="Attrib" > 属性名称 </ param >
        /// 
< param  name ="AttribContent" > 属性值 </ param >
        /// 
< param  name ="Content" > 新节点值 </ param >
        public static void XmlInsertElement(string xmlPath, string MainNode, string Element, string Attrib, string AttribContent, string Content)
        {
            XmlDocument objXmlDoc = new XmlDocument();
            objXmlDoc.Load(xmlPath);
            XmlNode objNode = objXmlDoc.SelectSingleNode(MainNode);
            XmlElement objElement = objXmlDoc.CreateElement(Element);
            objElement.SetAttribute(Attrib, AttribContent);
            objElement.InnerText = Content;
            objNode.AppendChild(objElement);
            objXmlDoc.Save(xmlPath);
        }

        #endregion

        #region 插入一节点不带属性

        public static void XmlInsertElement(string xmlPath, string MainNode, string Element, string Content)
        {
            XmlDocument objXmlDoc = new XmlDocument();
            objXmlDoc.Load(xmlPath);
            XmlNode objNode = objXmlDoc.SelectSingleNode(MainNode);
            XmlElement objElement = objXmlDoc.CreateElement(Element);
            objElement.InnerText = Content;
            objNode.AppendChild(objElement);
            objXmlDoc.Save(xmlPath);
        }

        #endregion
     #region 向一个节点添加属性
       /// 
< summary >
       /// 向一个节点添加属性
       /// 
</ summary >
       /// 
< param  name ="xmlPath" > xml文件路径 </ param >
       /// 
< param  name ="NodePath" > 节点路径 </ param >
       /// 
< param  name ="NodeAttribute1" > 要添加的节点属性的名称 </ param >
       /// 
< param  name ="NodeAttributeText" > 要添加属性的值 </ param >
        public static void AddAttribute(string xmlPath, string NodePath, string NodeAttribute1, string NodeAttributeText)
        {
            XmlDocument objXmlDoc = new XmlDocument();
            objXmlDoc.Load(xmlPath);
            XmlAttribute nodeAttribute = objXmlDoc.CreateAttribute(NodeAttribute1);
            XmlNode nodePath = objXmlDoc.SelectSingleNode(NodePath);
            nodePath.Attributes.Append(nodeAttribute);
            XmlElement xe = (XmlElement)nodePath;
            xe.SetAttribute(NodeAttribute1, NodeAttributeText);
            objXmlDoc.Save(xmlPath);
        }
        #endregion


如想要加入一个member的父节点,属性id值为7你可以这样来做:
 

//取得xml文件的路径
string  xmlPath  =  Server.MapPath( " ~/test.xml " );
        
string  parentNode = " member " ;
//在根节点下添加父节点member
        XmlHelper.AddParentNode(xmlPath, parentNode);
//刚添加的member节点添加一
        XmlHelper.AddAttribute(xmlPath, 
" phonebook/member " " id " " 7 " );


则xml文件就会变成这样

 

<? xml version = " 1.0 "  encoding = " utf-8 " ?>
< phonebook >
  
< member id = " 6 " >
    
< name > 456 </ name >
    
< qq > 5465 </ qq >
  
</ member >
  
< member id = " 5 " >
    
< name > jjjjj </ name >
    
< qq > 3456789 </ qq >
  
</ member >  
    
< member id = " 7 " >
  
</ member >
</ phonebook >


向新添加的节点member(id=7)的节点下加入节点名称为qq,值为123456的新节点,你可以这样做
 

      
  XmlHelper.XmlInsertElement(xmlPath, 
" //member[@id= " 7 " ] " " qq " " 123456 " );

则输出的xml为:
 

<? xml version="1.0" encoding="utf-8" ?>
< phonebook >
  
< member  id ="6" >
    
< name > 456 </ name >
    
< qq > 5465 </ qq >
  
</ member >
  
< member  id ="5" >
    
< name > jjjjj </ name >
    
< qq > 3456789 </ qq >
  
</ member >  
    
< member  id ="7" >
   
< qq > 123456 </ qq >
  
</ member >
</ phonebook >

增加节点我们就介绍到这里,只要你基本掌握了xpath语法,融会贯通,就可以利用上面几个公用方法对xml文件进行增加操作
 

下面我们介绍一下删除操作,删除共有两种,一是删除某一节点,一种是删除某一节点的属性。可以使用的方法如下:
 

  /**/ /// <summary>
        
/// 删除XML节点和此节点下的子节点
        
/// </summary>
        
/// <param name="xmlPath">xml文档路径</param>
        
/// <param name="Node">节点路径</param>

         public   static   void  XmlNodeDelete( string  xmlPath,  string  Node)
        
{
            XmlDocument objXmlDoc 
= new XmlDocument();
            objXmlDoc.Load(xmlPath);
            
string mainNode = Node.Substring(0, Node.LastIndexOf("/"));
            objXmlDoc.SelectSingleNode(mainNode).RemoveChild(objXmlDoc.SelectSingleNode(Node));
            objXmlDoc.Save(xmlPath);
        }


  
删除一个节点的属性 #region 删除一个节点的属性
        
/**//// <summary>
        
/// 删除一个节点的属性
        
/// </summary>
        
/// <param name="xmlPath">文件路径</param>
        
/// <param name="NodePath">节点路径(xpath)</param>
        
/// <param name="NodeAttribute">属性名称</param>

        public static void xmlnNodeAttributeDel(string xmlPath, string NodePath, string NodeAttribute)
        
{
            XmlDocument objXmlDoc 
= new XmlDocument();
            objXmlDoc.Load(xmlPath);
            XmlNode nodePath 
= objXmlDoc.SelectSingleNode(NodePath);
            XmlElement xe 
= (XmlElement)nodePath;
            xe.RemoveAttribute(NodeAttribute);
            objXmlDoc.Save(xmlPath);

        }

        
#endregion

如要删除属性id值为5的节点(包括其子节点),我们可以这样做:
 

     string  xmlPath  =  Server.MapPath( " ~/test.xml " );
        XmlHelper.XmlNodeDelete(xmlPath, 
" phonebook / member[@id= " 5 " ] " );

这时xml文件将变为:
 

<? xml version="1.0" encoding="utf-8" ?>
< phonebook >
  
< member  id ="6" >
    
< name > 456 </ name >
    
< qq >5465</qq>
  
</member >
  
< member  id ="5" >
    
< name > jjjjj </ name >
    
< qq > 3456789 </ qq >
  
</ member >  
    
< member  id ="7" >
   
< qq > 123456 </ qq >
  
</ member >
</ phonebook >

假如我们向id=6的父节点下子节点qq节点加一属性sex值为‘男‘,从上面可以看出这是可以可以做到的,则xml文件就变为:
 

<? xml version="1.0" encoding="utf-8" ?>
< phonebook >
  
< member  id ="6" >
    
< name > 456 </ name >
    
< qq  sex ='男'>5465</qq>
  
</member >
  
< member  id ="5" >
    
< name > jjjjj </ name >
    
< qq > 3456789 </ qq >
  
</ member >  
    
< member  id ="7" >
   
< qq > 123456 </ qq >
  
</ member >
</ phonebook >


假如我们要删除sex=“男”,我们可以这样做 :
 

        XmlHelper.xmlnNodeAttributeDel(xmlPath,  " //member[qq='5465']/qq " ' sex ' );
// 也可以
XmlHelper.xmlnNodeAttributeDel(xmlPath,  " //member[@id='6']/qq " ' sex ' );


关键是xpath语法,只要你能找到你的目的节点就行!!

你可能感兴趣的:(xml,C#,职场,操作,休闲)