zoukankan      html  css  js  c++  java
  • 浅学JSON——Json.NET之首次试手

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

    直接上代码:

    /// <summary>
    /// JSON数据转换为datatable类型数据
    /// </summary>
    /// <param name="strjson">JSON数据字符串</param>
    /// <returns>转换为DataTable类型的JSON数据</returns>
    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中。

    完整项目文件下载:华为网盘下载119网盘下载

    就是爱玩耍,各种玩![‘假’技术‘真’宅]
    个人网站:http://www.shisujie.com
  • 相关阅读:
    JQuery的Dom操作
    JQuer的简单应用
    JSBom联合Dom的应用
    Bom—浏览器对象模型
    正则表达式(其实就是预习)
    Js关于表单的事件应用
    JavaScript事件练习
    微信小程序实现微信登录
    Azure 数据资源管理器 -- 当 ADX 遇上 ML
    多快好省 -- Azure VMSS AI 推理篇
  • 原文地址:https://www.cnblogs.com/huaxia283611/p/3299482.html
Copyright © 2011-2022 走看看