c#中将json数据转换为dictionary并取出某个元素显示

using System;
using System.Collections.Generic;
using System.Web;
using System.Xml;
using System.Security.Cryptography;
using System.Text;
using LitJson;
using System.Runtime.Serialization;
using System.Runtime.Serialization.Json;
using System.IO;
using System.Web.Script.Serialization;

namespace WpfApplication1
{
    /// <summary>
    ///支付协议接口数据类,所有的API接口通信都依赖这个数据结构,
    /// 在调用接口之前先填充各个字段的值,然后进行接口通信,
    /// 这样设计的好处是可扩展性强,用户可随意对协议进行更改而不用重新设计数据结构,
    /// 还可以随意组合出不同的协议数据包,不用为每个协议设计一个数据包结构
    /// </summary>
    public class SiWoData
    {
        [DataMember(Name = "Success")]
        public string Success { get; set; }
        [DataMember(Name = "Msg")]
        public string Msg { get; set; }
        [DataMember(Name = "OrderId")]
        public string OrderId { get; set; }
        [DataMember(Name = "Name")]
        public string Name { get; set; }

        [DataMember(Name = "Plate")]
        public string Plate { get; set; }
        [DataMember(Name = "InTime")]
        public string InTime { get; set; }
        [DataMember(Name = "OutTime")]
        public string OutTime { get; set; }
        [DataMember(Name = "UserType")]
       public string UserType { get; set; }

        [DataMember(Name = "ParkingSite")]
        public string ParkingSite { get; set; }
        [DataMember(Name = "ParkingTime")]
        public string ParkingTime { get; set; }
        [DataMember(Name = "ParkingFee")]
        public string ParkingFee { get; set; }
        [DataMember(Name = "ParkingActFee")]
        public string ParkingActFee { get; set; }







        public Dictionary<string, object> dic = new Dictionary<string, object>();
       
       


        private Dictionary<string, object> JsonToDictionary(string jsonData)
        {

            //实例化JavaScriptSerializer类的新实例

            JavaScriptSerializer jss = new JavaScriptSerializer();

            try
            {

                //将指定的 JSON 字符串转换为 Dictionary<string, object> 类型的对象

                return jss.Deserialize<Dictionary<string, object>>(jsonData);

            }

            catch (Exception ex)
            {

                throw new Exception(ex.Message);

            }

        }
       

        public Dictionary<string, object> SiWodatas(string serverUrl_g, string Data)
        {

            //Json数据

            string json =  Service.HttpGetConnectToServer(serverUrl_g, Data);
            dic = JsonToDictionary(json);//将Json数据转成dictionary格式
            return dic;
      }
    }
}

在主函数中

string serverUrl_g = "http://qs.cnpms.cn:6050/getparkingfee/?from=&plate=%E4%BA%ACA99999";
            //上传的数据 
                string Data = DingDanHao.Text;
                string response_g = Service.HttpGetConnectToServer(serverUrl_g, Data);            
                SiWoData result = new SiWoData();
                Dictionary<string, object> dic=result.SiWodatas(serverUrl_g, Data);
                Label.Content = "车牌号:" + DingDanHao.Text + "\r\n" + "支付方式:微信支付" + "\r\n " +"驶入时间:"+ result.dic["InTime"] + "\r\n " +"驶出时间"+ result.dic["OutTime"];

result.dic["InTime"]
如此调用即可显示,即先将json数据转换为字典,返回字典,再实例化对象调用。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以使用 C# 中的 Newtonsoft.Json 库来将 JSON 转换为 CSV 文件。下面是一个简单的示例代码: ```csharp using Newtonsoft.Json; using Newtonsoft.Json.Linq; using System; using System.Collections.Generic; using System.IO; class Program { static void Main(string[] args) { // 读取 JSON 文件内容 string json = File.ReadAllText("input.json"); // 将 JSON 解析为对象 var data = JsonConvert.DeserializeObject<List<Dictionary<string, string>>>(json); // 获取所有属性名作为 CSV 的表头 var headers = new List<string>(data[0].Keys); // 创建 CSV 文件并写入表头 using (var writer = new StreamWriter("output.csv")) { writer.WriteLine(string.Join(",", headers)); // 逐行写入数据 foreach (var item in data) { var values = new List<string>(); // 按照表头的顺序获取每个属性的值 foreach (var header in headers) { values.Add(item.ContainsKey(header) ? item[header] : ""); } writer.WriteLine(string.Join(",", values)); } } Console.WriteLine("CSV 文件已生成!"); } } ``` 在这个示例中,我们假设输入的 JSON 数据是一个包含多个对象的数组,每个对象都是一个字典。通过使用 Newtonsoft.Json 库,我们可以将 JSON 字符串反序列化为一个包含字典的列表。然后,我们提取出所有属性名作为 CSV 文件的表头,并逐行写入每个对象的属性值。 记得替换代码中的 `input.json` 和 `output.csv` 分别为你的输入 JSON 文件和输出 CSV 文件的路径。确保你已经将 Newtonsoft.Json 包添加到你的项目中。 希望对你有所帮助!如果有任何进一步的问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值