Как получить DataSet.ReadXml для анализа атрибута DateTime как типизированного DateTime - PullRequest
1 голос
/ 09 февраля 2010

У меня есть строка XML, которая содержит даты в формате "дд / мм / гггг чч: мм: сс".

Я загружаю этот XML в набор данных, используя DataSet.ReadXml().

Как я могу гарантировать, что эта Дата хранится в наборе данных в виде типизированного DateTime, чтобы я мог соответственно сортировать, форматировать и RowFilter.

Мой тестовый жгут как ниже:

Страница ASPX:

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="XmlDateTypeList.aspx.cs" Inherits="Test.XmlDateTypeList" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
    <title>Test</title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
        <asp:GridView ID="GridView1" AutoGenerateColumns="false" runat="server">
            <Columns>
                <asp:BoundField DataField="Name" HeaderText="Name" />
                <asp:BoundField DataField="Date" HeaderText="Date" DataFormatString="{0:dddd dd MMMM yyyy}" />
            </Columns>
        </asp:GridView>
    </div>
    </form>
</body>
</html>

Код сзади:

using System;
using System.Data;
using System.IO;
using System.Linq;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Xml.Linq;

namespace Test
{
    public partial class XmlDateTypeList : System.Web.UI.Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {
            XDocument xDoc = new XDocument(
                new XElement("List",
                    new XElement("Item",
                        new XAttribute("Name", "A"),
                        new XAttribute("Date", "21/01/2010 00:00:00")
                    ),
                    new XElement("Item",
                        new XAttribute("Name", "B"),
                        new XAttribute("Date", "12/01/2010 00:00:00")
                    ),
                    new XElement("Item",
                        new XAttribute("Name", "C"),
                        new XAttribute("Date", "10/01/2010 00:00:00")
                    ),
                    new XElement("Item",
                        new XAttribute("Name", "D"),
                        new XAttribute("Date", "28/01/2010 00:00:00")
                    )
                )
            );

            DataSet dataSet = new DataSet();
            dataSet.ReadXml(new StringReader(xDoc.ToString()));

            GridView1.DataSource = dataSet.Tables[0];
            GridView1.DataBind();
        }
    }
}

1 Ответ

1 голос
/ 19 февраля 2010

Это больно, но основная проблема в том, что ваши xml-данные не могут быть строго типизированы в этом случае, потому что формат даты не в формате xs:date, и вы не можете изменить тип, когда данные находятся набор данных. Еще более усложняет то, что .NET не будет автоматически форматировать «28/01/2010 00:00:00» в качестве даты. Итак, просто скопируйте из одной таблицы данных в другую с правильным типом данных и переформатируйте строку даты по пути. Этот код работает, но далеко не элегантен. Удачи.

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Web;
    using System.Web.UI;
    using System.Web.UI.WebControls;
    using System.Xml.Linq;
    using System.Data;
    using System.IO;

    public partial class xmltest : System.Web.UI.Page
    {

        protected void Page_Load(object sender, EventArgs e)
        {
            XDocument xDoc = new XDocument(
                new XElement("List",
                    new XElement("Item",
                        new XAttribute("Name", "A"),
                        new XAttribute("Date", "21/01/2010 00:00:00")
                    ),
                    new XElement("Item",
                        new XAttribute("Name", "B"),
                        new XAttribute("Date", "12/01/2010 00:00:00")
                    ),
                    new XElement("Item",
                        new XAttribute("Name", "C"),
                        new XAttribute("Date", "10/01/2010 00:00:00")
                    ),
                    new XElement("Item",
                        new XAttribute("Name", "D"),
                        new XAttribute("Date", "28/01/2010 12:33:22")
                    )
                )
            );

            DataSet dataSet = new DataSet();
            dataSet.ReadXml(new StringReader(xDoc.ToString()));

            DataSet dataSet2 = dataSet.Clone();

            dataSet2.Tables[0].Columns[1].DataType = typeof(DateTime);

            // painful, painful copy over code from dataset1 to dataset2 
            foreach (DataRow r in dataSet.Tables[0].Rows)
            {

                DataRow newRow = dataSet2.Tables[0].NewRow();
                newRow["name"] = r["name"];

                newRow["Date"] = DateTime.ParseExact(r["Date"].ToString(), "dd/MM/yyyy HH:mm:ss", CultureInfo.CurrentCulture);

                dataSet2.Tables[0].Rows.Add(newRow);

            }

            GridView1.DataSource = dataSet2.Tables[0];
            GridView1.DataBind();
        }
    }
...