0

次の方法でC#でJSONをフォーマットしようとしています。次のテーブルがあるとしましょう

col1 col2 col3 col4
comA 1 2 3
comB 4 5 6
comC 7 8 9

JSON出力を次のようにしたい

[{ name: 'comA', data: [1,2,3]
}, { name: 'comB', data: [4,5,6] }, { name: 'comC', data: [7,8,9] }]

次のコードがあります

public class ChartLoc
{
    public string Category { get; set; }
    public string Data{ get; set; }
}

public void myFunc(){
    using (SqlConnection con = new SqlConnection(ConnectionString)
    {
        con.Open();
        using (SqlCommand cmd = new SqlCommand("select * from table", con))
        {
            using (SqlDataReader reader = cmd.ExecuteReader())
            {

                List<String> _Category = new List<String>();
                List<String> _Data = new List<String>();

                while (reader.Read())
                {


                    _Data.Add(reader["col2"].ToString() + ',' + reader["col3"].ToString() + ',' + reader["col4"].ToString());

                    if (reader["store"] != DBNull.Value) _Category.Add(reader["col1"].ToString());
                }
                JavaScriptSerializer jss = new JavaScriptSerializer();
                cl.Category = jss.Serialize(_Category); 
                cl.Data = jss.Serialize(_Data);
            }
        }
    }         
}

この出力は私に与えますが

cl.Category = ['comA','comB','comC'] cl.Data = ['1,2,3','4,5,6','7,8,9']

4

2 に答える 2

5

のような出力[{ name: 'comA', data: [1,2,3] }, { name: 'comB', data: [4,5,6] }, { name: 'comC', data: [7,8,9] }]が必要な場合は、オブジェクトを別の方法でシリアル化する必要があります。JSON には文字列ではなく数値のリストが必要なためList、クラス定義で数値を として表す必要があります。このようなものが動作するはずです:

[Serializable]
public class ChartLoc
{
    public string Category { get; set; }
    public List<int> Data{ get; set; }
}

public string myFunc()
{
    string jsonString = "";
    using (SqlConnection con = new SqlConnection(ConnectionString)
    {
        con.Open();
        using (SqlCommand cmd = new SqlCommand("select * from table", con))
        {
            using (SqlDataReader reader = cmd.ExecuteReader())
            {
                List<ChartLoc> _ChartLoc = new List<ChartLoc>();

                while (reader.Read())
                {
                    ChartLoc chart = new ChartLoc();
                    chart.Data.Add(int.Parse(reader["col2"].ToString()));
                    chart.Data.Add(int.Parse(reader["col3"].ToString()));
                    chart.Data.Add(int.Parse(reader["col4"].ToString()));

                    if (reader["store"] != DBNull.Value) 
                        chart.Category = reader["col1"].ToString();
                    _ChartLoc.Add(chart);
                }
                JavaScriptSerializer jss = new JavaScriptSerializer();
                jsonString = jss.Serialize(_ChartLoc);
            }
        }
    }
    return jsonString;         
}
于 2013-08-06T14:06:20.417 に答える
1

カテゴリとデータの組み合わせのセットを含む単一の JSON 文字列が必要な場合は、単一のオブジェクトをシリアル化する必要があります。ChartLoc のリストを提案してから、リストをシリアル化します。

さらに、Data オブジェクトが文字列の場合、文字列としてシリアル化されます (つまり、[1,2,3] ではなく "1,2,3")。本当にそれを修正したい場合は、int のコレクションが必要になります。

public class ChartLoc
{
    public string Category { get; set; }
    public List<int> Data { get; set; }
}
...
var chartLocs = new List<ChartLoc>();
chartLocs.Add(new ChartLoc { Category = "comA", Data = new List<int> { 1, 2, 3 } });
chartLocs.Add(new ChartLoc { Category = "comB", Data = new List<int> { 4, 5, 6 } });
chartLocs.Add(new ChartLoc { Category = "comC", Data = new List<int> { 7, 8, 9 } });

JavaScriptSerializer jss = new JavaScriptSerializer();
var json = jss.Serialize(chartLocs);

結果の JSON は、探しているものにはるかに似ています...

[{"カテゴリ":"comA","データ":[1,2,3]},{"カテゴリ":"comB","データ":[4,5,6]},{"カテゴリ": "comC","データ":[7,8,9]}]

于 2013-08-06T13:51:28.280 に答える