将复杂Json中的字典转换为列表<string>

时间:2016-02-18 09:00:09

标签: c# list dictionary

我有一个包含字典和列表的JSON字符串。对于解析,存在一个将列表类型从JSON字符串转换为字典的函数。我需要编写一个将Dictionary类型转换为List类型的函数。什么是最有效的方法呢?

例如......

假设这是我的样本json字符串 -

"{\"foo1\":{\"0\":\"0\",\"1\":\"S\",\"2\":\"S\",\"3\":\"J\",\"4\":\"Q\",\"5\":\"X\",\"6\":\"M\"},\"foo2\":{\"1\":\"one\" ,\"2\":\"two\",\"4\":\"four\",\"5\":\"five\",\"6\":\"six\",\"7\":\"seven\",\"8\":\"eight\"}"

从这里获取字典值并将它们转换为字符串列表是一种有效的方法。

1 个答案:

答案 0 :(得分:1)

    using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace ConsoleApplication11
{
    class Program
    {

        static void Main(string[] args)
        {
            string JSONIncludeBackslash = "{\"foo1\":{\"0\":\"0\",\"2\":\"S\",\"3\":\"J\",\"4\":\"Q\",\"5\":\"X\",\"6\":\"M\"},\"foo2\":{\"1\":\"one\",\"7\":\"seven\",\"8\":\"eight\"}}";
            Dictionary<string, string> JSONDictionary = JSONIncludeBackslash.Replace("\"", "").Replace(":{", "*").Replace("},", ",").Replace("}}", "").Replace("{", "").Replace("}", "").Split(',').ToDictionary(value => { return value.Split(':')[0].IndexOf("*") > -1 ? value.Split(':')[0].Split('*')[1] : value.Split(':')[0]; });

            Dictionary<string, string> JSONDictionary1 = JSONIncludeBackslash.Replace("\"", "").Replace(":{", "*").Replace("},", ",").Replace("}}", "").Replace("{", "").Replace("}", "").Split(',').ToDictionary(value => { return value.Split(':')[0].IndexOf("*") > -1 ? value.Split(':')[0].Split('*')[1] : value.Split(':')[0]; });
            foreach (var Entry in JSONDictionary1)
            {
                JSONDictionary[Entry.Key] = Entry.Value.Split(':')[1];
            }

            IList<KeyValuePair<string, string>> JSONList = JSONDictionary.ToList();
            foreach (var Item in JSONList)
            {
                Console.WriteLine(Item);
            }
            Console.ReadLine();
        }
    }
}

enter image description here