如何使用linq用逗号和冒号分隔字符串?

时间:2019-03-24 16:41:26

标签: c# linq class split

我有一个以下格式的传入字符串:“ 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方式或其他任何较短的方式使其更具可读性。还有其他方法可以做到这一点吗?

1 个答案:

答案 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();
相关问题