如何在json中处理这个字符串?

时间:2010-05-31 04:32:53

标签: c# json datatable newline

我在我的数据库表中存储多行文本框值...当我将此值转换为json时,它给出了一个错误Error: unterminated string literal ...

我的样本数据是,

Address Multiline textbox http://img249.imageshack.us/img249/9136/addressi.jpg

我将行提取到我的数据表,然后将其转换为json,

public string GetJSONString(DataTable table)
    {
        StringBuilder headStrBuilder = new StringBuilder(table.Columns.Count * 5); 
        for (int i = 0; i < table.Columns.Count; i++)
        {
            headStrBuilder.AppendFormat("\"{0}\" : \"{0}{1}¾\",", table.Columns[i].Caption, i);
        }
        headStrBuilder.Remove(headStrBuilder.Length - 1, 1);     
        StringBuilder sb = new StringBuilder(table.Rows.Count * 5); 
        sb.Append("{\"");
        sb.Append(table.TableName);
        sb.Append("\" : [");
        for (int i = 0; i < table.Rows.Count; i++)
        {
            string tempStr = headStrBuilder.ToString();
            sb.Append("{");
            for (int j = 0; j < table.Columns.Count; j++)
            {
                table.Rows[i][j] = table.Rows[i][j].ToString().Replace("'", "");
                tempStr = tempStr.Replace(table.Columns[j] + j.ToString() + "¾", table.Rows[i][j].ToString());
            }
            sb.Append(tempStr + "},");
        }
        sb.Remove(sb.Length - 1, 1); // trim last ,
        sb.Append("]}");
        return sb.ToString();
    }

上述方法似乎无法处理换行符...任何建议......

2 个答案:

答案 0 :(得分:2)

JSON字符串不能包含文字换行符(ASCII 10)。它必须编码为'\'然后'n'。正如Ignacio所说,你应该使用众多JSON库中的一个。

JSON.NET有built-in support用于序列化DataTables和其他类型。

答案 1 :(得分:0)

如果你不想远离第三方库,你也可以使用.NET内置的串行器

System.Web.Script.Serialization.JavaScriptSerializer

以下是一些代码,缺少许多检查,将DataTable转换为JSON

 ArrayList list = new ArrayList();
            Dictionary<string, object> jsonOutput = new Dictionary<string, object>();

            foreach (DataRow row in table.Rows)
            {
                foreach (DataColumn col in row.Table.Columns)
                {
                    if (row[col] == DBNull.Value)
                        jsonOutput.Add(col.ColumnName, "");
                    else
                        jsonOutput.Add(col.ColumnName, row[col]);
                }

                list.Add(jsonOutput);
                jsonOutput = new Dictionary<string, object>();
            }


            System.Web.Script.Serialization.JavaScriptSerializer jss = new System.Web.Script.Serialization.JavaScriptSerializer();
            return jss.Serialize(list);