• 实体、list 、xml之间的转化


    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text;
    using System.IO;
    using System.Data;
    using System.Xml;
    using System.Xml.Serialization;
     
    /// <summary>
    /// Xml序列化与反序列化
    /// </summary>
    public class XmlUtil
    {
        #region 反序列化
        /// <summary>
        /// 反序列化
        /// </summary>
        /// <param name="type">类型</param>
        /// <param name="xml">XML字符串</param>
        /// <returns></returns>
        public static object Deserialize(Type type, string xml)
        {
            try
            {
                using (StringReader sr = new StringReader(xml))
                {
                    XmlSerializer xmldes = new XmlSerializer(type);
                    return xmldes.Deserialize(sr);
                }
            }
            catch (Exception e)
            {
     
                return null;
            }
        }
        /// <summary>
        /// 反序列化
        /// </summary>
        /// <param name="type"></param>
        /// <param name="xml"></param>
        /// <returns></returns>
        public static object Deserialize(Type type, Stream stream)
        {
            XmlSerializer xmldes = new XmlSerializer(type);
            return xmldes.Deserialize(stream);
        }
        #endregion
     
        #region 序列化
        /// <summary>
        /// 序列化
        /// </summary>
        /// <param name="type">类型</param>
        /// <param name="obj">对象</param>
        /// <returns></returns>
        public static string Serializer(Type type, object obj)
        {
            MemoryStream Stream = new MemoryStream();
            XmlSerializer xml = new XmlSerializer(type);
            try
            {
                //序列化对象
                xml.Serialize(Stream, obj);
            }
            catch (InvalidOperationException)
            {
                throw;
            }
            Stream.Position = 0;
            StreamReader sr = new StreamReader(Stream);
            string str = sr.ReadToEnd();
             
            sr.Dispose();
            Stream.Dispose();
     
            return str;
        }
     
        #endregion
    }

    下面是测试代码:

    1. 实体对象转换到Xml

         

    public class Student
    {
        public string Name { set; get; }
        public int Age { set; get; }
    }
     
    Student stu1 = new Student() { Name = "okbase", Age = 10 };
    string xml = XmlUtil.Serializer(typeof(Student), stu1);
    Console.Write(xml);

    2. Xml转换到实体对象

    Student stu2 = XmlUtil.Deserialize(typeof(Student), xml) as Student;
    Console.Write(string.Format("名字:{0},年龄:{1}", stu2.Name, stu2.Age));

    3. DataTable转换到Xml

    // 生成DataTable对象用于测试
    DataTable dt1 = new DataTable("mytable");   // 必须指明DataTable名称
     
    dt1.Columns.Add("Dosage", typeof(int));
    dt1.Columns.Add("Drug", typeof(string));
    dt1.Columns.Add("Patient", typeof(string));
    dt1.Columns.Add("Date", typeof(DateTime));
     
    // 添加行
    dt1.Rows.Add(25, "Indocin", "David", DateTime.Now);
    dt1.Rows.Add(50, "Enebrel", "Sam", DateTime.Now);
    dt1.Rows.Add(10, "Hydralazine", "Christoff", DateTime.Now);
    dt1.Rows.Add(21, "Combivent", "Janet", DateTime.Now);
    dt1.Rows.Add(100, "Dilantin", "Melanie", DateTime.Now);
     
    // 序列化
    xml = XmlUtil.Serializer(typeof(DataTable), dt1);
    Console.Write(xml);

    4. Xml转换到DataTable

    // 反序列化
    DataTable dt2 = XmlUtil.Deserialize(typeof(DataTable), xml) as DataTable;
     
    // 输出测试结果
    foreach (DataRow dr in dt2.Rows)
    {
        foreach (DataColumn col in dt2.Columns)
        {
            Console.Write(dr[col].ToString() + " ");
        }
     
        Console.Write("
    ");
    }

    5. List转换到Xml

    // 生成List对象用于测试
    List<Student> list1 = new List<Student>(3);
     
    list1.Add(new Student() { Name = "okbase", Age = 10 });
    list1.Add(new Student() { Name = "csdn", Age = 15 });
    // 序列化
    xml = XmlUtil.Serializer(typeof(List<Student>), list1);
    Console.Write(xml);

    6. Xml转换到List

    List<Student> list2 = XmlUtil.Deserialize(typeof(List<Student>), xml) as List<Student>;
    foreach (Student stu in list2)
    {
        Console.WriteLine(stu.Name + "," + stu.Age.ToString());
    }

    xml转datatable

    private string ConvertDataTableToXML(DataTable xmlDS)
        {
            MemoryStream stream = null;
            XmlTextWriter writer = null;
            try
            {
                stream = new MemoryStream();
                writer = new XmlTextWriter(stream, Encoding.Default);
                xmlDS.WriteXml(writer);
                int count = (int)stream.Length;
                byte[] arr = new byte[count];
                stream.Seek(0, SeekOrigin.Begin);
                stream.Read(arr, 0, count);
                UTF8Encoding utf = new UTF8Encoding();
                return utf.GetString(arr).Trim();
            }
            catch
            {
                return String.Empty;
            }
            finally
            {
                if (writer != null) writer.Close();
            }
        } 
        private DataSet ConvertXMLToDataSet(string xmlData)
        {
          StringReader stream = null;
          XmlTextReader reader = null;
          try
          {
            DataSet xmlDS = new DataSet();
            stream = new StringReader(xmlData);
            reader = new XmlTextReader(stream);
            xmlDS.ReadXml(reader);
            return xmlDS;
          }
          catch (Exception ex)
          {
            string strTest = ex.Message;
            return null;
          }
          finally
          {
            if (reader != null)
            reader.Close();
          }
        }
    

      

  • 相关阅读:
    训练深度学习网络时候,出现Nan 或者 震荡
    Jupyter Notebook 的快捷键
    pyspark RandomForestRegressor 随机森林回归
    深度学习图像标注工具VGG Image Annotator (VIA)使用教程
    python 中 with 用法
    python 报错 SyntaxError: Non-ASCII character
    YOLO 详解
    Spark与Pandas中DataFrame对比
    利用WGET下载文件,并保存到指定目录
    http 三次握手
  • 原文地址:https://www.cnblogs.com/bysx/p/6573700.html
Copyright © 2020-2023  润新知