我在使用C#中Treeview与解析XML遇到的问题!

近日我在用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);
   }
  }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值