public clsSimuResultByOneGoods GetOneGoodsSimulationXML (строка PathAndFileName)
{
clsSimuResultByOneGoods OneGoods = new clsSimuResultByOneGoods();//自己定义的一个类
Hashtable AllLocationResult = новая Hashtable();
System.Xml.XmlTextReader r = новый XmlTextReader(PathAndFileName);
строка LocationID = "";
DataTable LocationTable = ноль;
в то время как (r.Read())
{
if(r.NodeType == XmlNodeType.Element)
{
переключатель (r.LocalName)
{
случай «Результат»:
OneGoods.GoodsCode = r.GetAttribute("GoodsCode");
OneGoods.From = Convert.ToDateTime(r.GetAttribute("FromDate"));
OneGoods.To = Convert.ToDateTime(r.GetAttribute("ToDate"));
перерыв;
кейс «Местоположение»:
LocationID = r.GetAttribute("ID");
LocationTable = новый DataTable();
LocationTable.Columns.Add("Дата",typeof(DateTime));
LocationTable.Columns.Add("SafetyStock",typeof(decimal));
LocationTable.Columns.Add("ПрогнозСпрос",typeof(десятичный));
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));
перерыв;
кейс «Рекорд»:
если (Таблица Расположение! = ноль)
{
DataRow dr = LocationTable.NewRow();
dr["Дата"] = Convert.ToDateTime(r.GetAttribute("Дата"));
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(др);
}
перерыв;
по умолчанию:
перерыв;
}
}
иначе, если (r.NodeType == XmlNodeType.EndElement)
{
переключатель (r.LocalName)
{
кейс «Местоположение»:
если (Таблица Расположение! = ноль)
{
LocationTable.ПринятьИзменения();
AllLocationResult.Add(LocationID,LocationTable);
Идентификатор местоположения = "";
ТаблицаРасположения = ноль;
}
перерыв;
по умолчанию:
перерыв;
}
}
}
OneGoods.AllLocationResult = AllLocationResult;
вернуть OneGoods;
}