C# 读 xml注释

有这么个需求:

要统计所有的配置文件,这些配置文件都xml格式,并把这些配置写到数据表里,如果有注释要把这些注释写到对应配置对象的描述字段上

 <item id="" key="-1" firstname="" secondname="" cssname="hy" decription="">
  </item>
  <!--111-->
 <item id="" key="-1" firstname="" secondname="" cssname="" decription=“">
  </item>

如上面所示,111 注释要写到下面的行记录对象上去

最终对象是: obj={id="",firstname="",secondname="",descrition="111"}

这个功能简单的不能再简单了,上线的产品非常多,各种配置文件也特别多,有的有注释,有的没有注释,怎么才能保证这些注释是加到对应的配置记录上去呢?

关键点在于怎么来判断注释和配置对象的关系:

读取到xml文件的根节点有两种类型:注释和元素节点,逻辑是:每次读取节点的时候先判断本次节点类型,如果是类型是注释,刚清除上一次的节点类型,保存本次节点类型,如果是

元素节点类型,刚判断上一次的节点类型是不是 注释类型 如果是 刚加到 描述字段,然后再清空上一次节点类型,记录这一次的节点类型,

流程如下:

代码:

flaglist中只存前一次节点元素类型,0表示 注释类型,1 表示元素类型:
 var attributes = "";
            var key = "";
            var tttt = (from config in XDoc.Descendants("configuration").Descendants("appSettings")
                        select config);
            foreach (var node in tttt.Nodes())
            {
                if (node.NodeType == System.Xml.XmlNodeType.Comment)
                {
                    flaglist.Clear();
                    attributes = node.ToString().Replace("<!--", "").Replace("-->", "");
                    flaglist.Add(0);
                }
                if (node.NodeType == System.Xml.XmlNodeType.Element)
                {
                    if (flaglist.Count == 1)
                    {
                        if (flaglist[0] == 1)
                        {
                            attributes = "";
                        }
                    }
                    flaglist.Clear();
                    key = ((XElement)node).Attribute("key").Value;
                    dic.Add(key, attributes);
                    flaglist.Add(1);
                }
            }
时间: 2024-11-05 11:38:52

C# 读 xml注释的相关文章

C#操作Xml:使用XmlReader读Xml

XmlDocument和XElement在读取Xml时要将整个Xml文档放到内存中去操作,这样做操作简单,但是很费内存和IO(可能是磁盘IO或者网络IO):而在有些场景下我们必须考虑尽可能节省内存和IO的开销,这时候就该XmlReader和XmlWriter出场了. XmlReader读取Xml需要通过Read()实例方法,不断读取Xml文档中的声明,节点开始,节点内容,节点结束,以及空白等等,直到文档结束,Read()方法返回false. 如下读取Xml内容实例代码和注释说明 ? //玉开技术

Eclipse中XML注释快捷键

eclipse中编辑java或C/C++文件时,注释的快捷键均为 "CTRL + / ",编辑xml文件时,该快捷键无效. eclipse XML 注释:CTRL + SHIFT + / 撤销注释:CTRL + SHIFT + \ 傻傻的手动输入<!--  -->好几个月了,偶然google下,真有这个快捷键-- 版权声明:本文为博主原创文章,未经博主允许不得转载.

读xml生成代码例子

读xml生成相应的  lua解析协议代码: #include <iostream> #include "tinyxml2.h" #include <fstream> #include <string> using namespace tinyxml2; using namespace std; std::ofstream file("readProto.lua",std::ios::ate|std::ios::binary); v

C#操作XML(读XML,写XML,更新,删除节点,与dataset结合等)【转载】

已知有一个XML文件(bookstore.xml)如下: Corets, Eva 5.95 1.插入节点 往节点中插入一个节点: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 XmlDocument xmlDoc=new XmlDocument(); xmlDoc.Load("bookstore.xml"); XmlNode root=xmlDoc.SelectSingleNode("bookstore");//查找

02_Android写xml文件和读xml文件

?? 新建Android项目 编写AndroidManifest.xml,使本Android项目具有单元测试功能和写外设的权限. <?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.itheima28.xmldemo" a

C# 读取XML注释

C#可以通过反射读取类的字段/方法等,可是该如何获取该字段的XML注释? 具体目的:有一个实体类,页面需要有一个与其对应的table,样式大体为 <tr> <td>地东经</td> <td> <input id='txt_Longitude' type='text' class='form-control' name='Longitude' /></td> <td>北纬</td> <td> <

C# : 操作Word文件的API - (将C# source中的xml注释转换成word文档)

这篇博客将要讨论的是关于: 如何从C#的source以及注释, 生成一份Word格式的关于各个类,函数以及成员变量的说明文档. 他的大背景如下...... 最近的一个项目使用C#, 分N个模块, 在项目的里程碑的时候, 日本的总公司要检查我们的成果物. 成果物包括源代码, 概要设计式样书(SD,System Design), 详细设计式样书(PD, Program Design), 自动化测试等等. 源代码必须要符合编码规范(每个函数都要有注释, 方法变量的命名规则等...) 这些检查都很正常,

【转】XML注释与Description标签及Java:注解(Annotation)的关系

NET中的规范标准注释(一) -- XML注释标签讲解 一.摘要 .Net允许开发人员在源代码中插入XML注释,这在多人协作开发的时候显得特别有用. C#解析器可以把代码文件中的这些XML标记提取出来,并作进一步的处理为外部文档. 这篇文章将展示如何使用这些XML注释. 在项目开发中,很多人并不乐意写繁杂的文档.但是,开发组长希望代码注释尽可能详细:项目规划人员希望代码设计文档尽可能详尽:测试.检查人员希望功能说明书尽可能详细等等.如果这些文档都被要求写的话,保持它们同步比进行一个战役还痛苦.

Sandcastle是微软提供的一个根据XML注释和DLL文件生成帮助文件的工具

Sandcastle是微软提供的一个根据XML注释和DLL文件生成帮助文件的工具,目前是在CodePlex上的一个开源项目,可以去这里下载:Sandcatle 项目Sandcastle 本身是一个console的程序,为了方便使用,我们可以使用他的GUI版本:Sandcastle Help File Builder. 第一步,为你写的代码添加XML注释 我们创建一个简单的ClassLibrary1项目最为示范: using System; using System.Collections.Gen