189 8069 5689

Json.NET的示例分析-创新互联

小编给大家分享一下Json.NET的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

创新互联自2013年起,公司以成都网站设计、成都网站建设、系统开发、网络推广、文化传媒、企业宣传、平面广告设计等为主要业务,适用行业近百种。服务企业客户千余家,涉及国内多个省份客户。拥有多年网站建设开发经验。为企业提供专业的网站建设、创意设计、宣传推广等服务。 通过专业的设计、独特的风格,为不同客户提供各种风格的特色服务。

首次遭遇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.NET的示例分析”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联网站制作公司行业资讯频道!

创新互联www.cdcxhl.cn,专业提供香港、美国云服务器,动态BGP最优骨干路由自动选择,持续稳定高效的网络助力业务部署。公司持有工信部办法的idc、isp许可证, 机房独有T级流量清洗系统配攻击溯源,准确进行流量调度,确保服务器高可用性。佳节活动现已开启,新人活动云服务器买多久送多久。


分享名称:Json.NET的示例分析-创新互联
文章路径:http://cdxtjz.cn/article/dpcpdg.html

其他资讯