c# – 将列表序列化为谷歌图表json数据表

前端之家收集整理的这篇文章主要介绍了c# – 将列表序列化为谷歌图表json数据表前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在寻找一种将对象列表序列化为谷歌图表json数据格式的通用方法.

This示例非常接近,但它使用的是数据表..

我希望这会涉及一些反思,有些可能是模型属性内容.
谁能指点我到图书馆或什么的?

如果我可以将这样的查询序列化为谷歌图表格式,那就更好了:

  1. var results = from m in be.cmsMember
  2. where m.FirstLogin != null
  3. && m.FirstLogin >= BitCoinGoLive
  4. group m by
  5.  
  6. new { Year = m.FirstLogin.Value.Year,Month = m.FirstLogin.Value.Month,Day = m.FirstLogin.Value.Day } into grp
  7. select new
  8. {
  9. Year = grp.Key.Year,Month = grp.Key.Month,Day = grp.Key.Day,Count = grp.Count()
  10. };

解决方法

我将创建自己的类层次结构,与Google的API匹配,然后使用JSON.NET对其进行序列化.可能的数据模型:
  1. public class Graph {
  2. public ColInfo[] cols { get; set; }
  3. public DataPointSet[] rows { get; set; }
  4. public Dictionary<string,string> p { get; set; }
  5. }
  6.  
  7. public class ColInfo {
  8. public string id { get; set; }
  9. public string label { get; set; }
  10. public string type { get; set; }
  11. }
  12.  
  13. public class DataPointSet {
  14. public DataPoint[] c { get; set; }
  15. }
  16.  
  17. public class DataPoint {
  18. public string v { get; set; } // value
  19. public string f { get; set; } // format
  20. }

然后是一个示例用法

  1. var graph = new Graph {
  2. cols = new ColInfo[] {
  3. new ColInfo { id = "A",label = "set A",type = "string" },new ColInfo { id = "B",label = "set B",new ColInfo { id = "C",label = "set C",type = "string" }
  4. },rows = new DataPointSet[] {
  5. new DataPointSet {
  6. c = new DataPoint[] {
  7. new DataPoint { v = "a" },new DataPoint { v = "b",f = "One" }
  8. }
  9. }
  10. },p = new Dictionary<string,string>()
  11. };
  12.  
  13. string json;
  14. //var s = new JsonSerializer();
  15. var s = new JavaScriptSerializer();
  16. /*using (var sw = new StringWriter()) {
  17. s.Serialize(sw,graph);
  18. json = sw.ToString();
  19. }*/
  20. var sw = new StringBuilder();
  21. s.Serialize(graph,sw);
  22. json = sw.ToString();

您可以使用Linq的Select()将数据转换为Google的数据模型,然后将其序列化为JSON.

猜你在找的C#相关文章