我有一个以下格式的传入字符串:“ LARGE:34,MEDIUM:25,SMALL:15”
我有以下课程:
public class Portion_Price
{
[DataMember]
public PortionSize PortionSize { get; set; }
[DataMember]
public Decimal ItemPrice { get; set; }
}
我想通过分割字符串来分配PortionSize和ItemPrice。 以下是我的工作代码:
str_portion_price = "LARGE:34,MEDIUM:25,SMALL:15";
List<Portion_Price> Portion_Price_List = new List<Portion_Price>();
if (!String.IsNullOrEmpty(str_portion_price))
{
List<string> str_por_pri = str_portion_price.Split(',').ToList();
foreach (var str_port_pric in str_por_pri)
{
Portion_Price single_portion_price = new Portion_Price();
List<string> portion_price = str_port_pric.Split(':').ToList();
single_portion_price.PortionSize = (PortionSize)Enum.Parse(typeof(PortionSize), portion_price[0]);
single_portion_price.ItemPrice = Convert.ToDecimal(portion_price[1]);
Portion_Price_List.Add(single_portion_price);
}
}
以上代码可以正常工作,但我想以Linq方式或其他任何较短的方式使其更具可读性。还有其他方法可以做到这一点吗?
答案 0 :(得分:5)
Portion_Price[] result =
str_portion_price.Split(',').Select(x=> new Portion_Price{
PortionSize = x.Split(':')[0], ItemPrice = decimal.Parse(x.Split(':')[1])})
.ToArray();
或仅进行一次拆分:
Portion_Price[] result =
str_portion_price.Split(',').Select(x=> { string[] s = x.Split(':');
return new Portion_Price
{
PortionSize = s[0],
ItemPrice = decimal.Parse(s[1])
};
}).ToArray();