· 网络编程· 网页设计· 图形图像· 网站联盟· 数 据 库· 站长时代· 业界资讯· 网站运营· 黑客攻防· 电脑技巧

站长资讯 News
· ASP 专区 · PHP 专区
· JSP 专区 · NET 专区
· XML 专区 · CGI 专区
· 其他相关
热门文章
· FlashMdy快乐行
· 什么是Web3.0
· The World浏览器秘技..
· 游荡在个人网站大潮..
· ASP中Request对象获..
· 今日(2006-11-26)域..
· 实战 FastCGI_2. 安..
· 黑客入侵“在线影院..
· [图文] 认识FrontPag..
· [图文] 谢文写诗袒露..
相关文章
· 我在台湾十天的软件..
· 我在成都当程序员
· 《我在联想的七年》..
· 我在软件公司成长的..
· [图文] 对话江南春:..
· 谈谈我在落伍熟悉的..
· 使用php动态生成gif..
· 我在桌面上删帖子
您当前的位置:资源库 -> 网络编程 -> NET 专区 -> 文章内容
我在使用C#中Treeview与解析XML遇到的问题
作者:无从考证  来源:中国软件  发布时间:2005-8-23 20:12:48  发布人:admin

减小字体 增大字体

 近日我在用C#将PDM中相关内容导入到TreeView的过程中,遇到一个很奇怪的问题,请各位大虾指点,谢谢!

private void ReadXml(string strFileName)
  {
   try
   {
         XmlDocument xmlDoc = new XmlDocument();
         xmlDoc.Load("c:\xxx.pdm");
         TreeNode rootNode = new TreeNode("PDM原始文档结构");
         trvXML.Nodes.Clear();
         this.trv_end.Nodes.Clear();
         tn_end2=new TreeNode("PDM表结构");
         trv_end.Nodes.Add(tn_end2);
         XmlNodeList rootList = xmlDoc.ChildNodes;
         foreach(XmlNode xmlnode in rootList)
         {
               TreeNode tn = new TreeNode(xmlnode.Name);
               if (xmlnode.HasChildNodes)
               {
                     rootNode.Nodes.Add(tn);
                     AnalyseXML(xmlnode, tn);
               }
         }
   
         this.trvXML.Nodes.Add(rootNode);
   }
   catch(Exception ex)
   {
         MessageBox.Show(ex.Message);
   }
   
  }

private void AnalyseXML(XmlNode node, TreeNode tnode)
  {
   try
   {
    XmlNodeList xnlAll = node.ChildNodes;
    TreeNode tn_end=new TreeNode();
    TreeNode tn=new TreeNode();
    string strChineseName="";
    bool TagFlag=false;
    bool TagFlag2=false;
    foreach(XmlNode snode in xnlAll)
    {
     //形成PDM原始文档功能树
     if(snode.NodeType==XmlNodeType.Text)
     {
      tn = new TreeNode(snode.Value+"["+snode.NodeType.ToString()+"]");
     }
     else
     {
      tn=new TreeNode(snode.Name+"("+snode.NodeType.ToString()+")");
     }
     //形成PDM原始文档功能树完毕
     //填充PDM表结构功能树
     if(snode.NodeType==XmlNodeType.Element&&snode.ParentNode.Name.Equals("o:Table"))
     {
      //获取表中文名
      if(snode.Name.Equals("a:Name"))
      {
       strChineseName=snode.FirstChild.Value;
      }
      //表英文名
      if(snode.Name.Equals("a:Code"))
      { 
       tn_end=new TreeNode(strChineseName+"["+snode.FirstChild.Value+"]",100,100);
       
       this.trv_end.TopNode.Nodes.Add(tn_end);
       this.trv_end.SelectedNode=tn_end;
       tn_end2=tn_end;
       TagFlag=true;
      }
      //表说明
      if(snode.Name.Equals("a:Comment"))
      { 
       TagFlag2=true;
       tn_end.Tag=snode.FirstChild.Value+"["+tn_end.Text.Substring(tn_end.Text.IndexOf("[")+1,tn_end.Text.IndexOf("_")-tn_end.Text.IndexOf("["));
      }
      if(TagFlag&&!TagFlag2)
      {
       tn_end.Tag="["+tn_end.Text.Substring(tn_end.Text.IndexOf("[")+1,tn_end.Text.IndexOf("_",tn_end.Text.IndexOf("["))-tn_end.Text.IndexOf("["));
      }
     }
     //填充PDM表结构功能树完毕
     //填充表各列字段
     if(snode.ParentNode.Name.Equals("o:Column")&&snode.ParentNode.ParentNode.Name.Equals("c:Columns"))
     {
      if(snode.Name.Equals("a:Name"))
      {
       tn_end=new TreeNode(snode.FirstChild.Value,1000,1000);
       trv_end.SelectedNode.Nodes.Add(tn_end);
       trv_end.SelectedNode=tn_end;
      }
      //字段英文名
      if(snode.Name.Equals("a:Code"))
      {
       tn_end=new TreeNode(snode.FirstChild.Value);
       trv_end.SelectedNode.Nodes.Add(tn_end);
      }
      //字段描述
      if(snode.Name.Equals("a:Comment"))
      {
       tn_end=new TreeNode(snode.FirstChild.Value);
       trv_end.SelectedNode.Nodes.Add(tn_end);
      }
      //字段类型
      if(snode.Name.Equals("a:DataType"))
      {
       tn_end=new TreeNode(snode.FirstChild.Value);
       trv_end.SelectedNode.Nodes.Add(tn_end);
       trv_end.SelectedNode=tn_end2;
      }
     }
     //各列字段填充完毕
     tnode.Nodes.Add(tn);
     if (snode.HasChildNodes)
     {
      AnalyseXML(snode, tn);
     }
    }
   }
   catch(Exception ex)
   {
    MessageBox.Show(ex.Message);
   }
  }



 
 
[] [返回上一页] [打 印]