asp.net中种数据对象转换成XML数据形式

近工作涉及到将Object转化为XML的数据格式。再网上找了一些资料。现在在这里总结一下目前使用到的方法

主要转换代码如下:

 代码如下 复制代码

public static Stream TransforToXMLFormat(object obj)
{
  XmlSerializerFactory xmlSerializerFactory = new XmlSerializerFactory();

  XmlSerializer xmlSerializer = new XmlSerializer(obj.GetType());

  MemoryStream stream = new MemoryStream();

  xmlSerializer.Serialize(stream, obj);

  return stream;
}

十分简单地使用了.Net的反射机制。生成出来的XML效果可以接受。重点要注意的几点:

1. 类必须要有Name这个属性否则转化会报错!

2. 使用[XmlAttribute]放于Name上面,即:

 代码如下 复制代码

[XmlAttribute]
public string Name;

可以将Name变成XML的属性而不是XML的元素,即:

 代码如下 复制代码

<Class xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" Name="......">

而不是:

 代码如下 复制代码

<Class xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">

<Name></Name>

</Class>

 

3. 想要将属性输出为XML的元素,属性必须是public的。

 4. 输出是使用了List<>,若想改变List里面每个元素的类名需要在List<>上面加上[XmlElement(ElementName="想要改变的名字")]即:

 代码如下 复制代码

[XmlElement(ElementName="想要改变的名字")]
public List<Type> Objects = null;

 附加将Hashtable里面的值转化成List的操作

 代码如下 复制代码

List<Object>= HashtableObject.Values.Cast<Object>().ToList();

DataTable转成XML文件

数据库表position有三个字段:
字段名             字段类型
position_id         int
position_name   varchar
position_desc     varchar
下面是Datatable转XML的生成源码:

 代码如下 复制代码
 protected void Page_Load(object sender, EventArgs e)
        {
            //通过数据访问层把position读取到Datatable
            BizRules.PersonnelDAL pl = new PersonnelDAL();
            DataTable dt = pl.Getposition();
            StringBuilder str = new StringBuilder();
            str.Append(DataTableToXml(dt));
            this.CreateXml(str.ToString(), "test.xml");
            Response.Write("生成test.xml成功");
        }
/// <summary>
        /// 生成文件
        /// </summary>
        /// <param name="val"></param>
        /// <param name="filename"></param>
        public void CreateXml(string val, string filename)
        {
            UnicodeEncoding ucode = new UnicodeEncoding();
            StreamWriter sw = new StreamWriter(Server.MapPath(filename));
            sw.WriteLine("<?xml version="1.0" encoding="utf-8"?>");
            sw.WriteLine(val);
            sw.Close();
            sw.Dispose();
        }
/// <summary>
        /// 转换成XML格式字符串
        /// </summary>
        /// <param name="dt"></param>
        /// <returns></returns>
        public string DataTableToXml(DataTable dt)
        {
            StringBuilder strXml = new StringBuilder();
            strXml.AppendLine("<XmlTable>");
            for (int i = 0; i < dt.Rows.Count; i  )
            {
                strXml.AppendLine("    <rows>");
                for (int j = 0; j < dt.Columns.Count; j  )
                {
                    strXml.AppendLine("        <"   dt.Columns[j].ColumnName   ">"   dt.Rows[i][j]   "</"   dt.Columns[j].ColumnName   ">");
                }
                strXml.AppendLine("    </rows>");
            }
            strXml.AppendLine("</XmlTable>");
            return strXml.ToString();
        }

下面看下生成XML文件的效果:

 代码如下 复制代码
<?xml version="1.0" encoding="utf-8"?>
<XmlTable>
 <rows>
  <position_id>29</position_id>
  <position_name>业务员</position_name>
  <position_desc></position_desc>
 </rows>
 <rows>
  <position_id>30</position_id>
  <position_name>业务经理</position_name>
  <position_desc></position_desc>
 </rows>
 <rows>
  <position_id>31</position_id>
  <position_name>业务总监</position_name>
  <position_desc></position_desc>
 </rows>
</XmlTable>

如果你使用DataSet,可以把DataSet转成Datatable,再使用上面的方法就可以了。

数据转换xml文件

从数据库的查询结果的数据保存到XML文件

 代码如下 复制代码

<%@ Import Namespace="System.Data" %>
<%@ Import Namespace="System.Data.OleDb" %>

<script language="VB" runat="server">

  Sub Page_Load(Sender As Object, E As EventArgs)

    Dim strConnection As String
    Dim strSQL        As String
    Dim objDataSet    As New DataSet()
    Dim objConnection As OleDbConnection
    Dim objAdapter    As OleDbDataAdapter

    strConnection = "Provider=Microsoft.Jet.OLEDB.4.0; " & _
                    "Data Source="+MapPath("EmployeeDatabase.mdb")
    strSQL = "SELECT FirstName, LastName FROM Employee;"

    objConnection = New OledbConnection(strConnection)
    objAdapter = New OledbDataAdapter(strSQL, objConnection)

    objAdapter.Fill(objDataSet, "Employees")

    objDataSet.WriteXml(Server.MapPath("Employee2.xml"))
   
    Response.Write("XML File Generated")

  End Sub

</script>

更多详细内容请查看:http://www.111cn.net/net/37/38865.htm

时间: 2024-09-20 09:37:55

asp.net中种数据对象转换成XML数据形式的相关文章

android XMl 解析神奇xstream 五: 把复杂对象转换成 xml ,并写入SD卡中的xml文件

前言:对xstream不理解的请看: android XMl 解析神奇xstream 一: 解析android项目中 asset 文件夹 下的 aa.xml 文件 android XMl 解析神奇xstream 二: 把对象转换成xml android XMl 解析神奇xstream 三: 把复杂对象转换成 xml android XMl 解析神奇xstream 四: 将复杂的xml文件解析为对象   1.建立JavaBeen package com.android10; public clas

ASP.NET中利用SQLXML WEB服务访问XML数据

asp.net|sql|web|web服务|xml|访问|数据      引言 使用SQLXML 的Web 服务从你的ASP.net应用程序中直接访问XML 数据       SQLXML 是扩展SQL 服务器现有的对检索和储存XML 数据的支持的一套附加的工具. 有了SQLXML 3.0,你现在就能使用SQL服务器展示Web 服务了.在SQLXML的Web 服务可以让用户执行存储过程,用户定义的功能,并且它们支持模板.       在这篇文章中,你将看出怎样展示一个作为Web 服务并构建一个简

map对象转换成xml

1. @XmlAccessorOrder.UNDEFINEDXmlAccessorOrder.UNDEFINED无序   @XmlAccessorOrder.ALPHABETICAL是指按属性的字母顺序排序. 2. @XmlType的propOrder 属性时,必须列出JavaBean对象中的所有属性,否则会报错   @XmlType(propOrder = { "id", "name", "age","book"})指定输出

android XMl 解析神奇xstream 二: 把对象转换成xml

前言:对xstream不理解的请看:android XMl 解析神奇xstream 一: 解析android项目中 asset 文件夹 下的 aa.xml 文件   1.Javabeen 代码 package com.android10; public class Product { private String name ; private String age ; public String getName() { return name; } public void setName(Str

挑逗你的智慧:mysql中的返回数据怎么转换成xml文档形式??

问题描述 我现在想要将mysql数据库中查询的结果以xml文档的形式返回给我,大家有没有好的办法,最好是mysql自带的FUNCTION:如在oracle中就可以 select DBMS_XMLGEN.GETXML('select * from user') from dual 至于mysql?????? 解决方案 http://www.zxbc.cn/html/20080906/65307.htmlShell> mysql -X -uroot -proot -e "use test; s

如何将一个json中的json字符串转换成一个USER对象。

我是温浩然: 通过Gson 可以将一个JSON,成功的转换为一个用户对象, JSONObject resJSON = JSONObject.fromObject(resData); System.out.println("resJSON"+resJSON); //把json中的user对象获取,并强转. Object userjson = resJSON.get("user"); String userString = userjson.toString(); //

java中对象的操作,将一个包含引用对象的对象转换成jsonStr格式的时候

问题描述 java中对象的操作,将一个包含引用对象的对象转换成jsonStr格式的时候 将一个包含引用对象的对象转换成jsonStr格式的时候以:引用对象名.引用对象属性:值,显示 例如:User user = new User(1,"tom"); {"user.id":"1","user.name":"tom"} 这种json字符串格式 解决方案 http://blog.csdn.net/snowdrea

C++中几种将整数转换成二进制输出的方法总结_C 语言

看<编程之美>第二节的时候,它是定义的一个整型,然后取位.但是他的那个或运算符号好像写错了,写成了异或符号"^",应该是"|".我就突然对二进制的输出感兴趣了.想知道怎样输出二进制.我们知道C++输出十六进制是cout〈〈hex〈〈 a:而八进制是cout〈〈 ocx〈〈 a;二进制则没有默认的输出格式,需要自己写函数进行转换,于是上网搜索了一下.网上思路真是广泛啊. 下面列出一些方法.  #include 〈iostream〉 #include 〈li

编写Python脚本把sqlAlchemy对象转换成dict的教程

  这篇文章主要介绍了编写Python脚本把sqlAlchemy对象转换成dict的教程,主要是基于Python的model类构建一个转换的方法,需要的朋友可以参考下 在用sqlAlchemy写web应用的时候,经常会用json进行通信,跟json最接近的对象就是dict,有时候操作dict也会比操作ORM对象更为方便,毕竟不用管数据库session的状态了. 假设数据库里有一张post表,其中一种方法就是 ? 1 2 p = session.query(Post).first() p.__di