Chinaunix首页 | 论坛 | 博客
  • 博客访问: 5648
  • 博文数量: 2
  • 博客积分: 65
  • 博客等级: 民兵
  • 技术积分: 30
  • 用 户 组: 普通用户
  • 注册时间: 2012-11-06 10:28
文章分类

全部博文(2)

最近访客

分类: C#/.net

2013-09-05 08:58:15

首次遭遇Json格式,缘由项目中用到Json数据,需要进行解析,为此,将Json数据转为了自己较为熟悉的DataTable格式,以此展示至DataGridView中,验证是否成功。

直接上代码:

/// 
/// JSON数据转换为datatable类型数据
/// 
/// JSON数据字符串
/// 转换为DataTable类型的JSON数据
private DataTable JSONToDataTable(string strjson)
{
    DataTable dt=new DataTable();
    DataColumn dc;
    DataRow dr;

    #region 添加列
    //用于添加列
    JsonReader jrcolumn = new JsonTextReader(new StringReader(strjson));

    bool hascolumn = false; //当前列名是否存在
    while (jrcolumn.Read())
    {
        //判断当前值是否是字段名
        if (jrcolumn.TokenType.ToString() == "PropertyName")
        {
            //判断当前列名是否在datatable中已存在
            foreach (DataColumn column in dt.Columns)
            {
                if (column.ColumnName == jrcolumn.Value.ToString())
                {
                    hascolumn = true;    //存在相同名称的列
                    break;
                }
            }

            //存在相同列,表示全部结束
            if (hascolumn == true)
            {
                break;
            }

            //添加新列
            dc = new DataColumn();
            dc.ColumnName = jrcolumn.Value.ToString();
            jrcolumn.Read();
            dc.DataType = System.Type.GetType(jrcolumn.ValueType.ToString()); //列类型
            dt.Columns.Add(dc);
        }
    }
    #endregion

    #region 添加数据记录
    //用于添加记录
    JsonReader jrrow = new JsonTextReader(new StringReader(strjson));

    dr = dt.NewRow();
    while (jrrow.Read())
    {
        if (jrrow.TokenType.ToString() == "PropertyName")
        {
            string columnname = jrrow.Value.ToString();
            jrrow.Read();
            dr[columnname] = jrrow.Value.ToString();
            if (columnname == dt.Columns[dt.Columns.Count - 1].ColumnName.ToString())
            {
                dt.Rows.Add(dr);
                dr = dt.NewRow();
            }
        }
    }
    #endregion

    return dt;
}

析:先获取列名——json数据的字段名称,然后获取具体数据。此段代码未对一次处理,后期将进一步改进。

成功时候,又以相同方式完成将数据加到ListView中。

完整项目文件下载:

 

标签: ,
阅读(293) | 评论(0) | 转发(0) |
0

上一篇:JSON资料汇总

下一篇:没有了

给主人留下些什么吧!~~