- [
- {
- "orderNo": "3213123123123",
- "time": "2016-09-09 12:23:33",
- "orderStatus": "1",
- "freeShipping": true,
- "fullCut": 20,
- "originalCost": 340,
- "actualPayment": 320,
- "goods": [
- {
- "UserId": "5",
- "GoodsId": "8",
- "Total": 40,
- "Number": 2,
- "ConCcoin": 0,
- "PayMode": "支付宝",
- "Price": "20.00",
- "goodsImg": "UpLoadImg/GoodsImage/546fda6d-8417-4b8f-bac6-3084dca420a9.jpg",
- "shopname": "两颗牙",
- "goodsTitle": "周村烧饼",
- "manmoney": "200",
- "jianmoney": "20",
- "jianyoufei": "8"
- },
- {
- "UserId": "5",
- "GoodsId": "7",
- "Total": 60,
- "Number": 1,
- "ConCcoin": 0,
- "PayMode": "支付宝",
- "Price": "60.00",
- "goodsImg": "UpLoadImg/GoodsImage/931be419-e9d3-4dae-ae93-5af619c217d9.jpg",
- "shopname": "两颗牙",
- "goodsTitle": "山东特产山东大枣1000g",
- "manmoney": "200",
- "jianmoney": "0",
- "jianyoufei": "10"
- }
- ]
- }
- ]
上面为要解析的JSON数据
- var json = "[{\"orderNo\": \"3213123123123\",\"time\": \"2016-09-09 12:23:33\",\"orderStatus\":\"1\", \"freeShipping\": true, \"fullCut\": 20,\"originalCost\": 340, \"actualPayment\": 320,\"goods\": [";
- json += " {\"UserId\": \"5\",\"GoodsId\": \"8\", \"Total\": 40, \"Number\": 2, \"Price\": \"20.00\", \"shopname\": \"两颗牙\", \"manmoney\": \"200\", \"jianmoney\": \"0\",\"jianyoufei\": \"10\"},";
- json += " {\"UserId\": \"5\",\"GoodsId\": \"7\", \"Total\": 60, \"Number\": 1, \"Price\": \"60.00\",\"shopname\": \"两颗牙\", \"manmoney\": \"200\", \"jianmoney\": \"0\",\"jianyoufei\": \"10\"},";
-
- json += " ]} ]";
-
- OrderDetails[] datas = JsonConvert.DeserializeObject<OrderDetails[]>(json);
- List<OrderDetailsInsert> insert = new List<OrderDetailsInsert>();
- foreach (OrderDetails data in datas)
- {
- var shopname = string.Empty;
- foreach (var item in data.goods)
- {
- OrderDetailsInsert getinfo = new OrderDetailsInsert();
- getinfo.orderno = data.orderno;
- getinfo.time = data.time;
- getinfo.orderStatus = data.orderStatus;
- getinfo.actualPayment = data.actualPayment;
- getinfo.orderno = data.orderno;
- if (data.freeShipping == true)
- {
- getinfo.Remark = "此商品符合包邮条件及满" + item.manmoney + "减" + data.fullCut + "条件:订单总金额:" + data.originalCost + "符合满减条件减去:" + data.fullCut + "实际付款金额:" + data.actualPayment;
- }
- else if (!string.IsNullOrEmpty(data.fullCut.ToString()) && data.fullCut != 0)
- {
- getinfo.Remark = "此商品符合满" + item.manmoney + "减" + data.fullCut + "条件:订单总金额:" + data.originalCost + "符合满减条件减去:" + data.fullCut + "实际付款金额:" + data.actualPayment;
- }
- else
- {
- getinfo.Remark = "订单实际付款金额:" + data.actualPayment;
- }
- getinfo.GoodsId = item.GoodsId;
- getinfo.Total = item.Total;
- getinfo.Number = item.Number;
- getinfo.Price = item.Price;
- insert.Add(getinfo);
- }
- }
要用的对象类
- public class OrderDetailsInsert
- {
- public string orderno { get; set; }
- public DateTime time { get; set; }
- public char orderStatus { get; set; }
-
- public Decimal actualPayment { get; set; }
-
- public int GoodsId { get; set; }
- public string Total { get; set; }
- public int Number { get; set; }
- public string Price { get; set; }
- public string Remark { get; set; }
- }
-
-
- public class OrderDetails
- {
- public string orderno { get; set; }
- public DateTime time { get; set; }
- public char orderStatus { get; set; }
- public bool freeShipping { get; set; }
- public Decimal fullCut { get; set; }
- public Decimal originalCost { get; set; }
- public Decimal actualPayment { get; set; }
-
- public GoodsInfoList[] goods { get; set; }
-
- }
-
- public class GoodsInfoList
- {
- public int UserId { get; set; }
- public int GoodsId { get; set; }
- public string Total { get; set; }
- public int Number { get; set; }
- public string Price { get; set; }
- public string shopname { get; set; }
- public string manmoney { get; set; }
-
- }
效果图:
参考资料:
http://blog.csdn.net/chinacsharper/article/details/9246627
http://blog.csdn.net/sgear/article/details/7587705
http://blog.csdn.net/leftfist/article/details/42435887