将Datalist导出为PDF,每页限制行数

时间:2013-11-22 10:45:36

标签: c# asp.net pdf

我正在尝试将SqlData导出为pdf,因为我正在尝试获取数据列表以打印预览。我已经按照这个示例。http://www.aspdotnet-suresh.com/2011/04/how-to-export-gridview-data-to-pdf.html这里网格视图数据显示。但我做了一些修改并试过要在DataList上获取数据。现在每件事都运行正常,我能够进行DataList的打印预览。只有一个问题就在那里,我想限制每页数据显示数量。就像我只想限制10Row每单pdf的页面。任何人都知道如何实现这样的功能?

简而言之,我需要在导出的pdf上使用分页功能,here是我目前正在获取的pdf

很抱歉,如果我的问题太简单了,但我是Asp.Net的新手

由于

1 个答案:

答案 0 :(得分:1)

该链接上的方法显示有点简单,但您可以修改它以解决您的问题。这是一些代码:

using System.Diagnostics;
using System.IO;
using iTextSharp.text;
using iTextSharp.text.pdf;

namespace RowsCountSample
{
    class Program
    {
        static void Main(string[] args)
        {
            using (var pdfDoc = new Document(PageSize.A4))
            {
                var pdfWriter = PdfWriter.GetInstance(pdfDoc, new FileStream("Test.pdf", FileMode.Create));
                pdfDoc.Open();

                var table1 = new PdfPTable(3);
                table1.HeaderRows = 2;
                table1.FooterRows = 1;

                //header row 
                var headerCell = new PdfPCell(new Phrase("header"));
                headerCell.Colspan = 3;
                headerCell.HorizontalAlignment = Element.ALIGN_CENTER;
                table1.AddCell(headerCell);

                //footer row 
                var footerCell = new PdfPCell(new Phrase("footer"));
                footerCell.Colspan = 3;
                footerCell.HorizontalAlignment = Element.ALIGN_CENTER;
                table1.AddCell(footerCell);

                //adding some rows 
                for (int i = 0; i < 70; i++)
                {
                    //adds a new row
                    table1.AddCell(new Phrase("Cell[0], Row[" + i + "]"));
                    table1.AddCell(new Phrase("Cell[1], Row[" + i + "]"));
                    table1.AddCell(new Phrase("Cell[2], Row[" + i + "]"));

                    //sets the number of rows per page
                    if (i > 0 && table1.Rows.Count % 7 == 0)
                    {
                        pdfDoc.Add(table1);
                        table1.DeleteBodyRows();
                        pdfDoc.NewPage();
                    }
                }

                pdfDoc.Add(table1);
            }

            //open the final file with adobe reader for instance. 
            Process.Start("Test.pdf");
        }
    }
}