没有找到合适的产品?
联系客服协助选型:023-68661681
翻译|使用教程|编辑:郑恭琳|2019-07-10 15:38:13.147|阅读 599 次
概述:尽管FastReport.Net为我们提供了一个插件供报表设计者用作JSON文件的数据源,但它也并不是对所有人都合适的。此插件适用于表示单独表的单级数据。如果数据具有多个嵌套级别,则必须尝试其他解决方案。
# 31款JAVA开发必备控件和工具 # 界面/文档管理/报表/IDE等4000款产品火热销售中 >>
相关链接:
尽管FastReport.Net为我们提供了一个插件供报表设计者用作JSON文件的数据源,但它也并不是对所有人都合适的。此插件适用于表示单独表的单级数据。如果数据具有多个嵌套级别,则必须尝试其他解决方案。
例如,使用Newtonsoft.Json库——在它的帮助下,您可以从JSON获取数据,从中创建列表并在代码报告中注册它。
让我们来看一个例子。我们要创建一个WinForms应用程序。在NuGet Manager的帮助下,安装Newtonsoft.Json包。在参考“Reference”中,添加指向库FastReport.dll的链接。
假设我们有商店经营的销售数据。所有这些数据都在一个文件中,但事实上它们是三个不同的实体:商店,店长,导购。这将是我们这个例子的json文件:
{ "Shops": [{ "Name": "First shop", "Managers": [{ "Name": "John", "Phone": "45443446343", "Sales": [{ "GoodId": "1", "Amount": "3" }, { "GoodId": "2", "Amount": "5" }, { "GoodId": "3", "Amount": "2" } ] }, { "Name": "Boris", "Phone": "8787964387", "Sales": [{ "GoodId": "15", "Amount": "8" }, { "GoodId": "12", "Amount": "2" }, { "GoodId": "13", "Amount": "2" } ] } ] }, { "Name": "Second shop", "Managers": [{ "Name": "Julia", "Phone": "5555555555", "Sales": [{ "GoodId": "1", "Amount": "30" }] }, { "Name": "Helen", "Phone": "8787964387", "Sales": [{ "GoodId": "2", "Amount": "8" }, { "GoodId": "3", "Amount": "26" }, { "GoodId": "1", "Amount": "2" } ] } ] } ] }
要反序列化此数据,我们需要具有与JSON中的字段对应的属性对象。
当然,如果JSON文档具有非常深的嵌套,那么它可能会非常累人。因此,这里有一个优秀的Web服务http://json2csharp.com/。您只需将有效的json放在输入字段中,按“Generate”按钮,然后获取现成的C#类。对于我们的json文档,将生成以下一组类:
public class Sale { public string GoodId { get; set; } public string Amount { get; set; } } public class Manager { public string Name { get; set; } public string Phone { get; set; } public List<Sale> Sales { get; set; } } public class Shop { public string Name { get; set; } public List<Manager> Managers { get; set; } } public class RootObject { public List<Shop> Shops { get; set; } }
让我们为它们创建一个单独的Sales.cs文件。
在表单中添加一个按钮。对于click事件,我们将创建一个处理程序:
private void RunBtn_Click(object sender, EventArgs e) { var json = JsonConvert.DeserializeObject<RootObject>(File.ReadAllText(@"Sales.json")); Report report = new Report(); report.RegisterData(json.Shops,"Shops"); report.Design(); }
如您所见,这里我们使用Newtonsoft.json库将json反序列化为RootObject,它具有属性Shops,这是一个商店列表。我们在报告中将此列表注册为数据源。并启用报表设计器“report designer”。使用单个按钮运行我们的应用程序并单击它。此时报表设计器显示空白报表。选择报告数据源:
根据此数据,创建报告模板:
如您所见,数据表“Data band”有一个子表,而该子表又有一个子数据表。
这些数据表上的数据根据数据源中的层次结构排列。运行报表:
这样,我们在Master-Detail报告中就获得了相关数据。我们不需要在表之间创建特殊关系来获取依赖关系。在JSON中大量嵌套数据的情况下,最好使用我们以上考虑的方法。
产品介绍 | 下载试用 | 优惠活动 | 在线客服 | 联系Elyn
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@evget.com
本文将为主要盘点如何将现有的ASP.NET MVC .NET 4.x/5/6项目迁移到Telerik UI for ASP.NET Core 7中的五个简单步骤,欢迎下载最新版体验~
本文主要介绍在MyEclipse中如何开始Spring开发,欢迎下载最新版IDE体验~
本文主要介绍在进行WinForm界面开发时,如何使用布局控件"WeifenLuo.WinFormsUI.Docking"。
本文主要介绍如何使用Qt Creator创建一个小的Qt应用程序 - 文本查找器。
一款全功能的Windows Forms、ASP.NET和MVC报表分析解决方案。
FastReport Online Designer一个跨平台的可视化Web报表设计器
服务电话
重庆/ 023-68661681
华东/ 18100878086
华南/ 18100878085
华北/ 17382392642
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@evget.com
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢
慧都科技有限公司 版权所有 Copyright 2003-2023 渝ICP备12000582号-13 渝公网安备
50010702500608号