C#JsonをDateTableに解析する方法

2467 ワード

この例では,C#がJsonをDateTableに解析する方法について述べる.皆さんの参考にしてください.具体的な実現方法は以下の通りである.

   #region   Json     DateTable ///  
  
/// Json DateTable。
/// Json : ///
 {table:[{column1:1,column2:2,column3:3},{column1:1,column2:2,column3:3}]}
/// 
/// Json
 /// DateTable public DataTable JsonToDataTable(string strJson)
{
//
var rg = new Regex(@(?<={)[^:]+(?=:[), RegexOptions.IgnoreCase);
 string strName = rg.Match(strJson).Value; DataTable tb = null;
 // strJson = strJson.Substring(strJson.IndexOf([) + 1);
 strJson = strJson.Substring(0, strJson.IndexOf(]));
 //
 rg = new Regex(@(?<={)[^}]+(?=})); MatchCollection mc = rg.Matches(strJson);
 for (int i = 0; i < mc.Count; i++) {
string strRow = mc[i].Value; string[] strRows = strRow.Split(',');
// if (tb == null) { tb = new DataTable();
 tb.TableName = strName; foreach (string str in strRows)
{ var dc = new DataColumn();
string[] strCell = str.Split(':');
dc.ColumnName = strCell[0].Replace(, );
 tb.Columns.Add(dc); }
 tb.AcceptChanges();
 } // DataRow dr = tb.NewRow();
for (int j = 0; j < strRows.Length; j++)
{ dr[j] = strRows[j].Split(':')[1].Replace(,
);
} tb.Rows.Add(dr);
tb.AcceptChanges();
 }
return tb; }
 #endregion

 
フォーマットは次のとおりです.

   { 
  
    table: [
        {
            column1: 1,
            column2: 2,
            column3: 3
        },
        {
            column1: 1,
            column2: 2,
            column3: 3
        }
    ]
}

 
例:

   [{Code:MetaDataId,Name:MetaDataId},{Code:MetadataCode,Name:  },{Code:SolutionName,Name:  }] 
 

フォーマット後:

   [ 
  
    {
        Code: MetaDataId,
        Name: MetaDataId
    },
    {
        Code: MetadataCode,
        Name:
    },
    {
        Code: SolutionName,
        Name:
    }
]

本稿で述べたことが皆さんのC#プログラム設計に役立つことを願っています.