C# DataSet的内容写成XML时如何格式化字段数据

大姨妈iu6
2013-10-12 · TA获得超过4115个赞
知道小有建树答主
回答量:1073
采纳率:0%
帮助的人:2527万
展开全部
// 导入命名空间。 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:
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式