C#中將DataSet的內容寫成XML

來源:互聯網
上載者:User
 許多讀者經常詢問一個問題,那就是在將DataSet的內容寫成XML時,如何格式化欄位資料。最常見的需求,就是希望日期時間值與數值資料能夠以所需的格式呈現於XML中。欲達此目的,可以採用下列兩種作法:

◆使用XmlConvert類。

◆將一個XSLT轉換套用至DataSet資料的XML表示。

程式範例

    圖 12-23所示是程式範例CH12_DemoForm018.cs的執行畫面,我們發現,從DataSet寫成XML的日期與薪資欄位資料皆已採用我們所要求的格式。基本上,本範例是利用XmlConvert類來完成欄位的格式化操作。相關程式碼編寫在按鈕的Click事件處理函數中,列示如下:

圖 12-23

// 匯入命名空間。

using System.Xml;

using System.Data.SqlClient;

using System.IO;

private void btnWriteDataSetToXml_Click(object sender, EventArgs e)

{

string myXmlFile = @"C:\DataSetOutputXml.xml";

try

{

// 建立一個 XmlTextReader 對象來讀取 XML 資料。

using(XmlTextReader myXmlReader =

new XmlTextReader(ds.GetXml(), XmlNodeType.Element, null))

{

// 使用指定的檔案與編碼方式來建立一個 XmlTextWriter 對象。

using(System.Xml.XmlTextWriter myXmlWriter =

new System.Xml.XmlTextWriter(myXmlFile, Encoding.UTF8))

{

myXmlWriter.Formatting = Formatting.Indented;

myXmlWriter.Indentation = 4;

myXmlWriter.WriteStartDocument();

string elementName = "";

// 解析並顯示每一個節點。

while(myXmlReader.Read())

{

switch(myXmlReader.NodeType)

{

case XmlNodeType.Element:

myXmlWriter.WriteStartElement(myXmlReader.Name);

elementName = myXmlReader.Name;

break;

case XmlNodeType.Text:

switch(elementName.ToLower())

{

case "出生日期":

// 要求轉換成字串的日期時間資料採用自訂的格式字串來格式化。

myXmlWriter.WriteString(XmlConvert.ToDateTime(myXmlReader.Value,

XmlDateTimeSerializationMode.Local).ToString(

"yyyy 年 MMMM dd 號 dddd,時間 HH 點 mm 分 ss 秒"));

break;

case "僱用日期":

case "加薪日期":

// 要求轉換成字串的日期時間資料採用簡短日期模式。

myXmlWriter.WriteString(XmlConvert.ToDateTime(myXmlReader.Value,

XmlDateTimeSerializationMode.Local).ToString("d"));

break;

case "起薪":

case "目前薪資":

// 要求轉換成字串的薪資值採用貨幣格式。

myXmlWriter.WriteString(XmlConvert.ToDecimal(

myXmlReader.Value).ToString("c"));

break;

default:

myXmlWriter.WriteString(myXmlReader.Value);

break;

}

break;

case XmlNodeType.EndElement:

myXmlWriter.WriteEndElement();

break;

}

}

}

}

// 讀取所輸出的 Xml 檔案,並將其內容顯示在 TextBox 文字框中。

txtXmlResult.Text = File.ReadAllText(myXmlFile);

}

catch(Exception ex)

{

MessageBox.Show(ex.Message);

}

}

 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.