zoukankan      html  css  js  c++  java
  • 用datatable 读写xml 及追加数据到xml

    1.写xml 

     /// <summary>
            /// 写错误日志
            /// </summary>
            /// <param name="ex"></param>
            public static void WriteErrorLog(Exception ex)
            {
               
                DataTable dt = new DataTable("ErrorLog");
                dt.Columns.Add("Date");
                dt.Columns.Add("Message");
                DataRow dr = dt.NewRow();
                dr["Date"] = DateTime.Now;
                dr["Message"] = ex.Message;
                dt.Rows.Add(dr);
                string path = Config.GetConfigValue("BASE_ERROR_FOLDER");//路径
                //目录是否存在
                if (!Directory.Exists(path))
                {
                    Directory.CreateDirectory(path);
                }
                string fullPath = path + "errorLog.xml";
                //文件是否存在
                if (!File.Exists(fullPath))
                {
                    dt.WriteXml(fullPath, XmlWriteMode.WriteSchema);
                   
                }
                else {
                    AppandXml(ex, fullPath);//存在,则追加
                }
               
            }

    2.追加数据

    /// <summary>
            /// 追加写入XML文件
            /// </summary>
            /// <param name="ex"></param>
            /// <param name="fullPath">文件全路径</param>
            public static void AppandXml(Exception ex, string fullPath)
            {
                XmlDocument xmlDoc = new XmlDocument();
                xmlDoc.Load(fullPath);
                XmlNode root = xmlDoc.SelectSingleNode("NewDataSet");//查找到根目录
                XmlElement errorLog_ele = xmlDoc.CreateElement("ErrorLog");
    
                XmlElement date_ele = xmlDoc.CreateElement("Date");
                date_ele.InnerText = DateTime.Now.ToString();
                errorLog_ele.AppendChild(date_ele);
    
                XmlElement message_ele = xmlDoc.CreateElement("Message");
                message_ele.InnerText =ex.Message;
                errorLog_ele.AppendChild(message_ele);
    
                root.AppendChild(errorLog_ele);
                xmlDoc.Save(fullPath);
            }
           

    3.读数据

    string filePath = (string)(Config.GetDataPath(StatType, Year, Week));
    
                DataTable dt = new DataTable();
                dt.ReadXml(filePath);
  • 相关阅读:
    new Date(str)返回 Invalid date问题
    时间倒计时
    js返回上一页并刷新 代码整理
    赋值变量值在标签里
    jQuery获取select选择的文本与值
    判断div里面的子集是否含有特定的类
    卷boot仅剩余XX空间
    ubuntu16.04 anaconda3安装
    ERROR 2003 (HY000): Can't connect to MySQL server on 'localhost' (10061)
    毕业设计
  • 原文地址:https://www.cnblogs.com/nik2011/p/4019585.html
Copyright © 2011-2022 走看看