我正在尝试将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的新手
由于
答案 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");
}
}
}