将TreeView中导出为XML数据

//使用范例:
TreeViewToXmlB m_TreeViewToXmlB = new TreeViewToXmlB();
 m_TreeViewToXmlB.exportToXml(this.TreeView1,Server.MapPath(@".\xml.xml"));

====================================================

using System;
using Microsoft.Web.UI.WebControls;
using System.Collections;
using System.IO;
//using System.Windows.Forms;

namespace treeview_DB
{
 /// <summary>
 /// 将TreeView中导出为XML数据
 /// </summary>
 public class TreeViewToXmlB
 {
  //XML每行的内容
  private string xmlLine = "";
  //用于写XML文件
  private StreamWriter sr;

   <summary>
  /// 构造函数
  /// </summary>
  public TreeViewToXmlB()
  {
           
  }

  /// <summary>
  /// 将TreeView中导出为XML数据
  /// </summary>
  /// <param name="tv">TreeView控件</param>
  /// <param name="filename">XML文件的保存路径</param>
  public void exportToXml(TreeView tv, string filename)
  {
   sr = new StreamWriter(filename, false, System.Text.Encoding.UTF8);
   //写文件头部内容
   //下面是生成RSS的OPML文件
   sr.WriteLine("<?xml version=\"1.0\" encoding=\"UTF-8\"?>");
   sr.WriteLine("<opml version=\"1.0\">");
   sr.WriteLine("<head>");
   sr.WriteLine("<title>RSS</title>");
   sr.WriteLine("</head>");
   sr.WriteLine("<body>");

   //遍历根节点
   foreach (TreeNode node in tv.Nodes)
   {
    if (node.Nodes.Count == 0)
    {
     xmlLine = GetRSSText(node);
    }
    else
    {
     xmlLine = GetDirectoryText(node);
    }

    sr.WriteLine(xmlLine);

    //递归遍历节点
    parseNode(node);
   }

   //写文件尾部内容
   sr.WriteLine("</body>");
   sr.WriteLine("</opml>");
   sr.Close();
  }

  //递归遍历节点内容,最关键的函数
  private void parseNode(TreeNode tn)
  {
   IEnumerator ie = tn.Nodes.GetEnumerator();

   while (ie.MoveNext())
   {
    TreeNode ctn = (TreeNode) ie.Current;

    //为最底层节点,即该节点为RSS节点
    if (ctn.Nodes.Count == 0)
    {
     xmlLine = GetRSSText(ctn);
     sr.WriteLine(xmlLine);
    }
    else//不是最底层节点,即该节点为目录节点
    {
     xmlLine = GetDirectoryText(ctn);
     sr.WriteLine(xmlLine);
    }

    //如果还有子节点则继续遍历
    if (ctn.Nodes.Count > 0)
    {
     parseNode(ctn);
    }
   }

   sr.WriteLine("</outline>");
  }

  //成生RSS节点的XML文本行
  private string GetRSSText(TreeNode node)
  {
   //根据Node属性生成XML文本
   string rssText = "<outline type=\"rss\" text=\"" + node.Text + "\" xmlUrl=\"URL\"/>";

   return rssText;
  }

  //成生目录节点的XML文本行
  private string GetDirectoryText(TreeNode node)
  {
   //根据Node属性生成XML文本
   string directoryText = "<outline text=\"" + node.Text + "\">";

   return directoryText;
  }
 }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
我们为什么要在LabVIEW使用XML文件?①它是许多服务器数据传输的基本格式,在网络编程有很大的几率要使用它。②它比ini文件功能强大,它可以编写复杂逻辑关系的数据配置文件,类似一个微型的数据库文件。。。。。。 感谢微软提供了OLE技术,使得不同程序之间可以通过预先指定的接口互相调用。微软提供了MSXML2.0, 4.0 及 6.0动态链接库来支援开发人员读写XML文件。 而LabVIEW正可以通过OLE自动化接口,调用MSXML*.dll动态链接库,完成对XML文件的操作。如果你的系统没有安装MSXML*.dll,可以去网上下载并安装就可以了。论坛有许多朋友已经使用该方式去读写EXCEL, WORD,ACCESS。 有了OLE接口是不是就能很方便的读写XML文件了呢?不是,因为其的操作是通过引用(Reference)来完成的,使用引用并不是免费的午餐,你必须时刻提防内存泄露,如果你忘记释放它,那么你就会在任务管理器看到:你的程序内存消耗在不断的增长。 更要命的是XML文件是以树的方式构成的,从上往下分大致有:Document, root node, node List, node,而node又包含parent node, child node,你的程序怎么才能组织好对它的调用?想想头都大了,是不是? 还好我们还有面向对象编程,把以上的东西都归下类,发现XML文件就是由Document, node list 和 node组成的,其他的都是根据这三个类派生出来的。那么就定义三个类,分别是CDoc, CNodeList 和 CNode由他们负责来完成对XML文件的操作。更方便的是,对于引用(Reference)的管理也都在这三个类当完成,这有效地减轻了程序的复杂度。 附件的程序是用LabVIEW8.5开发的,其包含了一份Sample.xml文件,供大家测试。 本程序是调用MSXML4.0接口来完成的,如果你系统里没有安装,那么将不能运行该程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值