C# XML转DataSet

本文展示了如何使用C#将从Web服务获取的XML字符串转换为DataSet。主要代码包括创建Web服务实例,调用方法获取XML,然后通过GetDataSetByXml方法将XML数据加载到DataTable中。XML数据包含多个Person节点,每个节点有ExamNO属性。转换后的DataSet包含这些信息。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.主要实现代码如下:

PEISWS_Report_Print p1 = new PEISWS_Report_Print();  //webservice

string sGroupResult = p1.RequestExamReportList();   //调webservice返回xml文件

if (!string.IsNullOrEmpty(sGroupResult))
{
     DataTable dt = GetDataSetByXml(sGroupResult).Tables[0];  //XML转Datatable 实现方法GetDataSetByXml
}

        /// <summary>
        /// xml转dataset
        /// </summary>
        /// <param name="xmlData"></param>
        /// <returns></returns>
        public static DataSet GetDataSetByXml(string xmlData)
        {
            StringReader stream = null;     //System.IO
            XmlTextReader reader = null;  //System.Xml
            try
            {
                DataSet xmlDS = new DataSet();
                stream = new StringReader(xmlData); //从stream装载到XmlTextReader               
                reader = new XmlTextReader(stream);
                xmlDS.ReadXml(reader);
                return xmlDS;
            }
            catch (System.Exception ex)
            {
                throw ex;
            }
            finally
            {
                if (reader != null) reader.Close();
            }
        }    

2.sGroupResult内容大致为:

<ReportList>

  <Person>

           <ExamNO>体检号</ExamNO>

  </Person>

       <Person>

          <ExamNO>体检号</ExamNO>

  </Person>

</ReportList>

3. 返回DataSet如图片所示:

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值