从XML中读取数据到内存的实例

导读:
  public clsSimuResultByOneGoods GetOneGoodsSimulationXML(string PathAndFileName)
  {
  clsSimuResultByOneGoods OneGoods = new clsSimuResultByOneGoods();//自己定义的一个类
  Hashtable AllLocationResult = new Hashtable();
  System.Xml.XmlTextReader r = new XmlTextReader(PathAndFileName);
  string LocationID = "";
  DataTable LocationTable = null;
  while(r.Read())
  {
  if(r.NodeType == XmlNodeType.Element)
  {
  switch(r.LocalName)
  {
  case "Result":
  OneGoods.GoodsCode = r.GetAttribute("GoodsCode");
  OneGoods.From = Convert.ToDateTime(r.GetAttribute("FromDate"));
  OneGoods.To = Convert.ToDateTime(r.GetAttribute("ToDate"));
  break;
  case "Location":
  LocationID = r.GetAttribute("ID");
  LocationTable = new DataTable();
  LocationTable.Columns.Add("Date",typeof(DateTime));
  LocationTable.Columns.Add("SafetyStock",typeof(decimal));
  LocationTable.Columns.Add("ForecastDemand",typeof(decimal));
  LocationTable.Columns.Add("FinalOutput",typeof(decimal));
  LocationTable.Columns.Add("FinalInput",typeof(decimal));
  LocationTable.Columns.Add("SimuStock",typeof(decimal));
  LocationTable.Columns.Add("SimuStockTime",typeof(decimal));
  LocationTable.Columns.Add("ImportWorkDay",typeof(bool));
  LocationTable.Columns.Add("ImportWorkDay",typeof(bool));
  break;
  case "Record":
  if(LocationTable != null)
  {
  DataRow dr = LocationTable.NewRow();
  dr["Date"] = Convert.ToDateTime(r.GetAttribute("Date"));
  if(r.GetAttribute("SafetyStock") != null &&r.GetAttribute("SafetyStock") != "")
  dr["SafetyStock"] = Convert.ToDecimal(r.GetAttribute("SafetyStock"));
  if(r.GetAttribute("ForecastDemand") != null &&r.GetAttribute("ForecastDemand") != "")
  dr["ForecastDemand"] = Convert.ToDecimal(r.GetAttribute("ForecastDemand"));
  if(r.GetAttribute("FinalInput") != null &&r.GetAttribute("FinalInput") != "")
  dr["FinalInput"] = Convert.ToDecimal(r.GetAttribute("FinalInput"));
  if(r.GetAttribute("FinalOutput") != null &&r.GetAttribute("FinalOutput") != "")
  dr["FinalOutput"] = Convert.ToDecimal(r.GetAttribute("FinalOutput"));
  if(r.GetAttribute("SimuStock") != null &&r.GetAttribute("SimuStock") != "")
  dr["SimuStock"] = Convert.ToDecimal(r.GetAttribute("SimuStock"));
  if(r.GetAttribute("SimuStockTime") != null &&r.GetAttribute("SimuStockTime") != "")
  dr["SimuStockTime"] = Convert.ToDecimal(r.GetAttribute("SimuStockTime"));
  if(r.GetAttribute("ImportWorkDay") != null &&r.GetAttribute("ImportWorkDay") != "")
  dr["ImportWorkDay"] = Convert.ToBoolean(r.GetAttribute("ImportWorkDay"));
  if(r.GetAttribute("ExportWorkDay") != null &&r.GetAttribute("ExportWorkDay") != "")
  dr["ExportWorkDay"] = Convert.ToBoolean(r.GetAttribute("ExportWorkDay"));
  LocationTable.Rows.Add(dr);
  
  }
  break;
  default:
  break;
  }
  }
  else if(r.NodeType == XmlNodeType.EndElement)
  {
  switch(r.LocalName)
  {
  case "Location":
  if(LocationTable != null)
  {
  LocationTable.AcceptChanges();
  AllLocationResult.Add(LocationID,LocationTable);
  LocationID = "";
  LocationTable = null;
  }
  break;
  default:
  break;
  }
  }
  }
  OneGoods.AllLocationResult = AllLocationResult;
  return OneGoods;
  
  }

本文转自
http://hi.baidu.com/wanglianbin/blog/item/7114d0629e26d6dde7113a8d.html
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值