C1 ASP.NET Wijmo GridView导出为PDF格式

发布时间:2013/11/05 00:11 发布者:Roger

返回博客中心

Wijmo GridView没有内置数据导出Excel、PDF的接口函数,如果要导出为Excel或者PDF文件,需要写代码实现。

本文通过一个简单的途径实现了导出为PDF文件的方法,供参考:

  • 通过使用 StringWriter and HtmlTextWriter 类来保存Grid数据为HTML字符串。
  • 然后,通过其他控件生成PDF文件。 如我们这里用到的C1PdfDocument控件 (C1PdfDocument是C1Pdf dll的一部分)
  • 创建一个C1PdfDocument类的实例后,便可获得一个PDF文档的空白页面。你可以通过类如DrawStringHtml(), DrawString()的函数来写PDF文档内容
    主要代码如下:
  1: public void ExportToPDF(C1GridView grid)
  2:  {
  3:     C1PdfDocument pdfdoc = new C1PdfDocument();
  4:     RectangleF rect = pdfdoc.PageRectangle;
  5:     Font font = new Font("Times New Roman", 12);
  6:  
  7:     StringWriter sw = new StringWriter();
  8:     HtmlTextWriter htmlwriter = new HtmlTextWriter(sw);
  9:  
 10:     System.Web.UI.HtmlControls.HtmlForm form1 = new System.Web.UI.HtmlControls.HtmlForm();
 11:     grid.AllowPaging = false;
 12:     grid.DataBind();
 13:     form1.Controls.Add(grid);
 14:     form1.Controls[0].RenderControl(htmlwriter);
 15:     StringReader streader = new StringReader(sw.ToString());
 16:     string str = streader.ReadToEnd();
 17:     string savepath = Server.MapPath("Grapecity_TestData.pdf");
 18:  
 19:     for (int start = 0; ; )
 20:      {
 21:         start = pdfdoc.DrawStringHtml(str, font, Brushes.Black, rect, start);
 22:         // 导出完成
 23:         if (start >= int.MaxValue)
 24:          {
 25:            break;
 26:           }
 27:         // 插入新页面
 28:        pdfdoc.NewPage();
 29:      }
 30:  
 31:    pdfdoc.Save(savepath);
 32:    streader.Close();
 33:    lblUpdate.Text = "数据以及被导出为PDF文档";
 34:    System.Diagnostics.Process.Start(savepath);
 35:  }
 36: 

 

代码如下:

 


关于葡萄城

赋能开发者!葡萄城是专业的集开发工具、商业智能解决方案、低代码开发平台于一身的软件和服务提供商,为超过 75% 的全球财富 500 强企业提供服务。葡萄城专注控件软件领域30年,希望通过模块化的开发控件、灵活的低代码应用开发平台等一系列开发工具、解决方案和服务,帮助开发者快速响应复杂多变的业务需求,最大程度地发挥开发者的才智和潜能,让开发者的 IT 人生更从容更美好。

了解详情,请访问葡萄城官网