C#操作XML非常简单

一是写入:

生明一个xelment 再在它的父节点Add就可以,也可以用生明的节点.SetAttribute("节点名称","节点对应的值");

二是读取:

一样也是先生明再得到其子节点再
                    if (xe.Name == "Contrast")
                   
                        if (xe.GetAttribute("IsSelect") == "true")

即再根据其节点名称 得节点,根据节点属性获取属性值。

 /// <summary>
/// 写操作日志
/// </summary>
/// <param name="logInfo">要写入日志的内容</param>
/// <param name="flagOfResult">成功还是失败</param>
public static void WriteLog1(this string logInfo, int flagOfResult)
{
XmlDocument doc = new XmlDocument();
string path = System.Environment.CurrentDirectory + "\\Log.xml";
doc.Load(path);
//查找根节点
XmlNode root = doc.SelectSingleNode("Logs");
//创建一个DataInfos节点
XmlElement xe = doc.CreateElement("Log"); XmlElement operater = doc.CreateElement("操作人");
operater.InnerText = "Admin";
xe.AppendChild(operater);
XmlElement OprateResult = doc.CreateElement("结果");
OprateResult.InnerText = flagOfResult == ? "成功" : "失败";
xe.AppendChild(OprateResult);
XmlElement OprateMsg = doc.CreateElement("结果信息");
OprateMsg.InnerText = logInfo;
xe.AppendChild(OprateMsg);
XmlElement OprateTime = doc.CreateElement("操作时间");
OprateTime.InnerText = DateTime.Now.ToShortDateString();
xe.AppendChild(OprateTime);
root.AppendChild(xe);
doc.Save(path); }

#region  写操作日志   这种格式  
              //      <Log>
              //<操作人>Admin</操作人>
              //<结果>成功</结果>
              //<结果信息>数据导出成功!</结果信息>
              //<操作时间>2014/5/27</操作时间>
              //</Log>

/// <summary>
        /// 写操作日志
        /// </summary>
        /// <param name="logInfo">要写入日志的内容</param>
        /// <param name="flagOfResult">成功还是失败</param>
        public static void WriteLog1(this string logInfo, int flagOfResult)
        {
            XmlDocument doc = new XmlDocument();
            string path = System.Environment.CurrentDirectory + "\\Log.xml";
            doc.Load(path);
            //查找根节点
            XmlNode root = doc.SelectSingleNode("Logs");
            //创建一个DataInfos节点
            XmlElement xe = doc.CreateElement("Log");

XmlElement operater = doc.CreateElement("操作人");
            operater.InnerText = "Admin";
            xe.AppendChild(operater);
            XmlElement OprateResult = doc.CreateElement("结果");
            OprateResult.InnerText = flagOfResult == 1 ? "成功" : "失败";
            xe.AppendChild(OprateResult);
            XmlElement OprateMsg = doc.CreateElement("结果信息");
            OprateMsg.InnerText = logInfo;
            xe.AppendChild(OprateMsg);
            XmlElement OprateTime = doc.CreateElement("操作时间");
            OprateTime.InnerText = DateTime.Now.ToShortDateString();
            xe.AppendChild(OprateTime);
            root.AppendChild(xe);
            doc.Save(path);

}

#endregion

#region  写操作日志----------------这种格式     <Log 操作人="Admin" 操作结果="成功" 结果详情="数据导出成功!" 操作时间="2014/5/2714:37" />

/// <summary>
        /// 写操作日志
        /// </summary>
        /// <param name="logInfo">要写入日志的内容</param>
        /// <param name="flagOfResult">成功还是失败</param>
        public static void WriteLog(this string logInfo, int flagOfResult)
        {
            try
            {
                XmlDocument doc = new XmlDocument();
                string path = System.Environment.CurrentDirectory + "\\Log.xml";
                doc.Load(path);
                //查找根节点
                XmlNode root = doc.SelectSingleNode("Logs");
                //创建一个DataInfos节点
                XmlElement xe = doc.CreateElement("Log");
                xe.SetAttribute("操作人", "Admin");
                xe.SetAttribute("操作结果", flagOfResult == 1 ? "成功" : "失败");
                xe.SetAttribute("结果详情", logInfo);
                xe.SetAttribute("操作时间", DateTime.Now.ToShortDateString() + DateTime.Now.ToShortTimeString());
                root.AppendChild(xe);
                doc.Save(path);
            }
            catch (Exception)
            {

return;
            }

}

#endregion

#region   根据配置文件初始化SQL语句

/// <summary>
        /// 根据表名及其配置文件生成T_SQL语句及要生成的Excel的表头
        /// </summary>
        /// <param name="TableName">要查询的Table的表名</param>
        /// <returns>正常:返回List<string>表头String及T_SqLString;异常:返回单个以“错误”+异常信息的List</returns>
        public static List<string> InitSqlString(this string TableName)
        {
            List<string> listResult = new List<string>();
            try
            {
                StringBuilder sbOfT_SQL = new StringBuilder();
                StringBuilder sbOfExcelHeadName = new StringBuilder();
                sbOfT_SQL.Append("select ");
                XmlDocument doc = new XmlDocument();
                doc.Load(System.Environment.CurrentDirectory + "\\TableDetailInfo\\" + TableName + ".xml");
                XmlNodeList xmlList = doc.SelectSingleNode("ContrastList").ChildNodes;
                foreach (XmlNode xn in xmlList)
                {
                    XmlElement xe = (XmlElement)xn;
                    if (xe.Name == "Contrast")
                    {
                        if (xe.GetAttribute("IsSelect") == "true")
                        {
                            sbOfT_SQL.Append(xe.GetAttribute("DestField"));
                            sbOfExcelHeadName.Append(xe.GetAttribute("SourceField"));
                            sbOfExcelHeadName.Append(",");
                            sbOfT_SQL.Append(",");
                        }

}
                }
                sbOfT_SQL.Remove(sbOfT_SQL.ToString().Length - 1, 1);
                sbOfExcelHeadName.Remove(sbOfExcelHeadName.ToString().Length - 1, 1);
                sbOfT_SQL.Append(" from " + TableName);
                listResult.Add(sbOfExcelHeadName.ToString());
                listResult.Add(sbOfT_SQL.ToString());

}
            catch (Exception ex)
            {
                listResult.RemoveRange(0, listResult.Count);
                listResult.Add("错误");
            }
            return listResult;
        }

#endregion

XML常用操作的更多相关文章

  1. xml常用操作(js、sql、vb)

    我们经常会用到xml操作,如下介绍了js.sql.vb等对xml的操作. JS创建xml对象 //创建对象 function getDataXML() {     var objTds = $(&qu ...

  2. TinyXml 操作XML 常用操作

    源代码下载:http://sourceforge.net/projects/tinyxml/files/ 如下是一个XML片段:    <Persons>        <Perso ...

  3. logback logback.xml常用配置详解(三)

    logback logback.xml常用配置详解 <filter> <filter>: 过滤器,执行一个过滤器会有返回个枚举值,即DENY,NEUTRAL,ACCEPT其中之 ...

  4. Hadoop HDFS文件常用操作及注意事项

    Hadoop HDFS文件常用操作及注意事项 1.Copy a file from the local file system to HDFS The srcFile variable needs t ...

  5. SQL Server 2008 对XML 数据类型操作

    原文 http://www.cnblogs.com/qinjian123/p/3240702.html 一.前言 从 SQL Server 2005 开始,就增加了 xml 字段类型,也就是说可以直接 ...

  6. xml常用四种解析方式优缺点的分析×××××

    xml常用四种解析方式优缺点的分析 博客分类: xml   最近用得到xml的解析方式,于是就翻了翻自己的笔记同时从网上查找了资料,自己在前人的基础上总结了下,贴出来大家分享下. 首先介绍一下xml语 ...

  7. Flex 对Xml对象操作

    一.读取.xml文件() import flash.events.Event;   import flash.net.URLLoader;   import flash.net.URLRequest; ...

  8. fiddler常用操作

    fiddler常用操作 标签(空格分隔): fiddler fidrdler抓取https请求: fiddler是一个很好的抓包工具,但是默认的是抓取HTTP的,对于pc的https的会提示网页不安全 ...

  9. Hbase常用操作(增删改查)

    Hbase常用操作(增删改查) [日期:2014-01-03] 来源:Linux社区  作者:net19880504 [字体:大 中 小]     运行Eclipse,创建一个新的Java工程“HBa ...

随机推荐

  1. 【BZOJ4945】[Noi2017]游戏 2-SAT

    [BZOJ4945][Noi2017]游戏 题目描述 题解:2-SAT学艺不精啊! 这题一打眼看上去是个3-SAT?哎?3-SAT不是NPC吗?哎?这题x怎么只有8个?暴力走起! 因为x要么不是A要么 ...

  2. EasyNVR H5直播流媒体解决方案前端构建之:如何播放自动适配RTMP/HLS直播播放

    之前在进行EasyNVR多屏开发的时候,由于多屏功能不需要在手机端展示出来(pc多播放为RTMP,手机端播放为HLS),因此只注意到了引用videojs来进行rtmp的播放.由于不同项目需求不同,对h ...

  3. S2S4H整合注意问题

    整合过程中出现问题记录: 1.The import javax.servlet.http.HttpServletRequest cannot be resolved 解决办法:在tomcat的lib目 ...

  4. 九度OJ 1050:完数 (数字特性)

    时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:7535 解决:3125 题目描述: 求1-n内的完数,所谓的完数是这样的数,它的所有因子相加等于它自身,比如6有3个因子1,2,3,1+2+ ...

  5. 如果数据需要被多个应用程序消费的话,推荐使用 Kafka,如果数据只是面向 Hadoop 的,可以使用 Flume

    https://www.ibm.com/developerworks/cn/opensource/os-cn-kafka/index.html Kafka 与 Flume 很多功能确实是重复的.以下是 ...

  6. php验证身份证号码有效性

    <?php // 18位身份证校验码有效性检查 // idcard_checksum18('...'); function idcard_checksum18($idcard) { if (st ...

  7. 【题解】Counting D-sets(容斥+欧拉定理)

    [题解]Counting D-sets(容斥+欧拉定理) 没时间写先咕咕咕. vjCodeChef - CNTDSETS 就是容斥,只是难了一二三四五\(\dots \inf\)点 题目大意: 给定你 ...

  8. 【题解】UVA10140 [Prime Distance]

    [题解]UVA10140 Prime Distance 哈哈哈哈\(miller-rabbin\)水过去了哈哈哈 还能怎么办呢?\(miller-rabbin\)直接搞.枚举即可,还跑得飞快. 当然此 ...

  9. MLGBZ

    April cloudy, boss rainy, told me he want to kick But coming so,Formosa Heart sad , Down,down,down W ...

  10. absolute布局的替代实现

    京东商城首页标价定位 小横条首页导航的下拉 1.京东商城首页标价定位 .p-img{ height: 130px;} .p-price{ margin:-28px 0 0 74px;} .price{ ...