博客园 - 灵感之源的Smart Forge智能工厂 - 利用iTextSharp把DataTable导出为PDF和RTF(Rich Text Format)文件

来源:百度文库 编辑:神马文学网 时间:2024/05/01 21:07:45
利用iTextSharp把DataTable导出为PDF和RTF(Rich Text Format)文件
相信每个业务系统都有报表输出的需要,一般采用第三方报表工具,如水晶报表等等。我们也可以直接采用PDF生成类库类实现,不过代码要写多些。
使用.NET开发的生成PDF文件的类库不少,我之前也介绍过开源代码2004/1220-PDF格式/文件相关。其中最具有代表性的,我认为是iTextSharp,它来自JAVA开发的iText,已经相当稳定了,同样移植自iText的iTextDotNet(J#),但我偏好C#,所以这次采用iTextSharp。
相比其它PDF生成类库,iTextSharp有一个优势:它还能生成RTF(Rich Text Format,一些人翻译作富文本,这种是Windows的写字板专用的,也可以给Office Word正确识别和打开)、XML、HTML和Markup。而且代码非常类似,差别就在于Writer类型不一样,足见作者对OO的理解和掌握能力;
我的需求很简单,把一个DataTable(DataSet也可)导出为一个PDF文件。大家可以想像到:这个“映射”是很直接的,因为DataTable的Rows和Columns就对应PDF中的Cells(Rows)。所以可以估计,这个代码也就2个循环,10行代码左右。
关键点在于:中文的支持。iTextSharp支持中文,但来得不直接,要通过BaseFont.CreateFont()来实现:
   BaseFont baseFont =
    BaseFont.CreateFont(
    "C:\\WINDOWS\\FONTS\\SIMHEI.TTF",
    BaseFont.IDENTITY_H,
    BaseFont.NOT_EMBEDDED);
   Font font = new Font(baseFont, 9);

这里有一个缺点,就是必须指定字体路径,而Environment.SpecialFolder却不包含字体路径,其它获取方法也是有不少的,如用Win32 API等,也可以来点野蛮的:
 Environment.GetFolderPath(Environment.SpecialFolder.System) + @"\..\Fonts\"
PDF函数:

        public static bool ConvertDataTableToPDF(DataTable Data, string PDFFile, string FontPath, float FontSize)
        {
            Document document = new Document();
            PdfWriter writer = PdfWriter.GetInstance(document, new FileStream(PDFFile, FileMode.Create));
            document.Open();

            BaseFont baseFont =
                BaseFont.CreateFont(
                FontPath,
                BaseFont.IDENTITY_H,
                BaseFont.NOT_EMBEDDED);
            Font font = new Font(baseFont, FontSize);

            PdfPTable table = new PdfPTable(Data.Columns.Count);
            for (int i = 0; i < Data.Rows.Count; i++)
            {
                for (int j = 0; j < Data.Columns.Count; j++)
                {
                    table.AddCell(new Phrase(Data.Rows[i][j].ToString(), font));
                }
            }

            document.Add(table);
            document.Close();
            writer.Close();
            return true;
        }

PDF调用:
ConvertDataTableToPDF(Table, @".\test.pdf", "C:\\WINDOWS\\FONTS\\SIMSUN.TTC,1", 9); //这里使用宋体,大小9pt。
RTF函数:

        public static bool ConvertDataTableToRtf(DataTable Data, string RtfFile, string FontPath, float FontSize)
        {
            Document document = new Document();
            RtfWriter2 writer = RtfWriter2.GetInstance(document, new FileStream(RtfFile, FileMode.Create));
            document.Open();

            BaseFont baseFont =
                BaseFont.CreateFont(
                FontPath,
                BaseFont.IDENTITY_H,
                BaseFont.NOT_EMBEDDED);
            Font font = new Font(baseFont, FontSize);

            Table table = new Table(Data.Columns.Count);
            for (int i = 0; i < Data.Rows.Count; i++)
            {
                for (int j = 0; j < Data.Columns.Count; j++)
                {
                    table.AddCell(new Phrase(Data.Rows[i][j].ToString(), font));
                }
            }

            document.Add(table);
            document.Close();
            //writer.Close();
            return true;
        }

RTF调用:
ConvertDataTableToRtf(Table, @".\test.rtf", "C:\\WINDOWS\\FONTS\\SIMSUN.TTC,1", 9);
生成PDF和RTF的代码是不是很类似?代码很直接,大家根据自己的实际需要改造吧。
生成出来的PDF和RTF在大小上差异很大:6个字段*2000条记录,PDF为200k左右,RTF竟然达到5.5M左右。大家衡量使用什么吧。
btw.iTextSharp刚推出了3.0.7版本:New release iTextSharp 3.0.7 (2005-08-24)
参考:
1、itext官方教程字体部分:http://itextdocs.lowagie.com/tutorial/fonts/index.html
2、iTextSharp全攻略:http://www.zzchina.net/article/17/16571.htm
3、iTextSharp官方教程代码:iTextSharp (iText#) tutorial update version_xyz