c# 对一下XML文档进行添加删改的实例

XML文件名为bcastr.xml

结构如下:

<?xml version="1.0" encoding="utf-8"?> 
<bcaster> 
  <item id="79" item_url="PicNews/Img/u=404630538,2075277077" link="HTML/050/AI_20081017_50_53_79.html" itemtitle="111111111111111111" /> 
  <item id="78" item_url="PicNews/Img/Index_04_01_06.jpg" link="HTML/050/AI_20081017_50_53_78.html" itemtitle="zengjia" /> 
  <item id="77" item_url="PicNews/Img/bsxwf.jpg" link="HTML/050/AI_20081017_50_53_77.html" itemtitle="中国药科大学研究生部" /> 
  <item id="76" item_url="PicNews/Img/江宁大门.jpg" link="HTML/050/AI_20081017_50_53_76.html" itemtitle="研究生部图片新闻" /> 
  <item id="75" item_url="PicNews/Img/中国药科大学校标(完美2).jpg" link="HTML/050/AI_20081017_50_53_75.html" itemtitle="新闻测试图片新闻" /> 
</bcaster>
添加节点的函数:

/// 将图片新闻信息写入到图片新闻播放器的XML文件集中 
    /// </summary> 
    /// <param name="picpath">图片路径</param> 
    /// <param name="htmlpath">图片新闻网址</param> 
    /// <param name="title">标题</param> 
    public void WritePicNewsXML(string picpath, string htmlpath, string title,string aid) 
    { 
        XmlDocument xmlDoc; 
        xmlDoc = new XmlDocument(); 
        xmlDoc.Load(HttpContext.Current.Server.MapPath("../PicNews/bcastr.xml"));

        XmlNodeList xnl = xmlDoc.SelectSingleNode("bcaster").ChildNodes; 
        //if (xnl.Count <= 5)//保持首页图片新闻不超过5条 
        //{ 
            XmlNode rootnode = xmlDoc.SelectSingleNode("bcaster");

            XmlElement fel = (XmlElement)rootnode.FirstChild; 
             
            XmlElement el = xmlDoc.CreateElement("item");//添加子节点及属性 
            el.SetAttribute("id", aid); 
            el.SetAttribute("item_url", picpath); 
            el.SetAttribute("link", htmlpath); 
            el.SetAttribute("itemtitle", title); 
            rootnode.PrependChild(el);//将新加入的图片新闻添加到第一个位置 
            if (xnl.Count > 5) 
            { 
                XmlNode lxn = rootnode.LastChild; 
                rootnode.RemoveChild(lxn);//删除最末尾的图片新闻 
            } 
            

            xmlDoc.Save(HttpContext.Current.Server.MapPath("../PicNews/bcastr.xml")); 
        //} 
    }
修改XML节点的属性的函数:

/// <summary> 
    /// 修改XML属性 
    /// </summary> 
    /// <param name="picpath"></param> 
    /// <param name="htmlpath"></param> 
    /// <param name="title"></param> 
    /// <param name="aid"></param> 
    public void EditPicNewsXML(string picpath, string htmlpath, string title, string aid) 
    {

        XmlDocument xmlDoc; 
        xmlDoc = new XmlDocument(); 
        xmlDoc.Load(HttpContext.Current.Server.MapPath("../PicNews/bcastr.xml"));

        XmlNodeList xnl = xmlDoc.SelectSingleNode("bcaster").ChildNodes; 
        foreach (XmlNode xn in xnl) 
        { 
            XmlElement xe = (XmlElement)xn; 
            if (xe.GetAttribute("id") == aid)//如果节点存在则改写 
            { 
                xe.SetAttribute("item_url", picpath); 
                xe.SetAttribute("link", htmlpath); 
                xe.SetAttribute("itemtitle", title); 
                break; 
            } 
        }

        xmlDoc.Save(HttpContext.Current.Server.MapPath("../PicNews/bcastr.xml")); 
    }
删除指定的XML节点的函数:

 /// <summary> 
    /// 删除XML指定节点 
    /// </summary> 
    /// <param name="aid"></param> 
    public void DelPicNewsXML(string aid) 
    { 
        XmlDocument xmlDoc; 
        xmlDoc = new XmlDocument(); 
        xmlDoc.Load(HttpContext.Current.Server.MapPath("../PicNews/bcastr.xml"));

        XmlNodeList xnl = xmlDoc.SelectSingleNode("bcaster").ChildNodes; 
        foreach (XmlNode xn in xnl) 
        { 
            XmlElement xe = (XmlElement)xn; 
            if (xe.GetAttribute("id") == aid)//如果节点存在删除 
            { 
                xe.RemoveAll(); 
                break; 
            } 
        }

        xmlDoc.Save(HttpContext.Current.Server.MapPath("../PicNews/bcastr.xml")); 
    }
以上为在使用图片新闻播放器bactr时对其XML动态更新

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/j_jake/archive/2008/10/17/3092886.aspx

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
回答: 在C#中,我们可以使用XmlReader和XmlDocument类来对XML文件进行操作。 使用XmlReader类,可以按顺序读取XML文件的内容,并执行相应的操作。首先,我们需要创建一个XmlReaderSettings对象,并设置一些选项,比如忽略空白和注释。然后,使用XmlReader.Create方法创建一个XmlReader实例,并传入文件路径和XmlReaderSettings对象。接下来,可以使用while循环和Read方法来遍历XML文件的节点,并执行相应的操作。\[1\] 使用XmlDocument类,可以加载整个XML文件,并使用XPath表达式来选择和操作XML节点。首先,我们需要实例化一个XmlDocument对象,并使用Load方法加载XML文件,文件路径为绝对路径。然后,可以使用SelectSingleNode方法和XPath表达式来选择特定的节点。如果需要选择节点的子节点,可以使用ChildNodes属性将子节点集合成一个列表。\[2\] 下面是一个XML文件的示例: <bookstore> <book category="CHILDREN"> <title>Harry Potter</title> <author>J K. Rowling</author> <year>2005</year> <price>29.99</price> </book> <book category="WEB"> <title>Learning XML</title> <author>Erik T. Ray</author> <year>2003</year> <price>39.95</price> </book> </bookstore> 使用C#XML文件进行操作,可以根据具体需求选择使用XmlReader或XmlDocument类。 #### 引用[.reference_title] - *1* *2* *3* [C#解析XML文件](https://blog.csdn.net/simplenthpower/article/details/128669633)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值