本文介绍了将数据导出为pdf时出现问题的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

Folloing函数将datatable作为参数并生成pdf作为输出..



这样工作正常......但是当pdf生成第一个时出现问题pdf页面附带列标题,但如果数据转到下一页没有任何标题..



如何将标题添加到下一页..


注意:对于此功能,我使用过iTextSharp.dll

Folloing function takes datatable as parameter and produces pdf as output..

This works fine... But Problem arises that When pdf generates the first page of pdf comes with Column header but if data goes to next page There is not any header..

How to add header to next page also..

Note: For this function i have used iTextSharp.dll

public void ExportToPdf(DataTable myDataTable)
{
  Session["CompanyName"] = "Mrinal";
  Document pdfDoc = new Document(PageSize.A4, 10, 10, 10, 10);
  try
  {
    PdfWriter.GetInstance(pdfDoc,
      System.Web.HttpContext.Current.Response.OutputStream);
    pdfDoc.Open();
    Chunk c = new Chunk("" +
      System.Web.HttpContext.Current.Session["CompanyName"] + "",
      FontFactory.GetFont("Verdana", 11));
    Paragraph p = new Paragraph();
    p.Alignment = Element.ALIGN_CENTER;
    p.Add(c);
    pdfDoc.Add(p);
    string clientLogo = HttpContext.Current.Session["CompanyName"].ToString();
    clientLogo = clientLogo.Replace(" ", "");
    string clogo = clientLogo + ".jpg";
    string imageFilePath = HttpContext.Current.Server.MapPath("../ClientLogo/" + clogo + "");
    iTextSharp.text.Image jpg = iTextSharp.text.Image.GetInstance(imageFilePath);
    //Resize image depend upon your need   
    jpg.ScaleToFit(80f, 60f);
    //Give space before image   
    jpg.SpacingBefore = 0f;
    //Give some space after the image   
    jpg.SpacingAfter = 1f;
    jpg.Alignment = Element.HEADER;
    pdfDoc.Add(jpg);
    Font font8 = FontFactory.GetFont("ARIAL", 7);
    DataTable dt = myDataTable;
    if (dt != null)
    {
      //Craete instance of the pdf table and set the number of column in that table  
      PdfPTable PdfTable = new PdfPTable(dt.Columns.Count);
      PdfPCell PdfPCell = null;
      for (int rows = 0; rows < dt.Rows.Count; rows++)
      {
        for (int column = 0; column < dt.Columns.Count; column++)
        {
          PdfPCell = new PdfPCell(new Phrase(new Chunk(dt.Rows[rows].Column].ToString(), font8)));
          PdfTable.AddCell(PdfPCell);
        }
      }
      //PdfTable.SpacingBefore = 15f; // Give some space after the text or it may overlap the table            
      pdfDoc.Add(PdfTable); // add pdf table to the document   
    }
    pdfDoc.Close();
    Response.ContentType = "application/pdf";
    Response.AddHeader("content-disposition", "attachment; filename= SampleExport.pdf");
    System.Web.HttpContext.Current.Response.Write(pdfDoc);
    Response.Flush();
    Response.End();
    //HttpContext.Current.ApplicationInstance.CompleteRequest();  
  }
  catch (DocumentException de)
  {
    System.Web.HttpContext.Current.Response.Write(de.Message);
  }
  catch (IOException ioEx)
  {
    System.Web.HttpContext.Current.Response.Write(ioEx.Message);
  }
  catch (Exception ex)
  {
    System.Web.HttpContext.Current.Response.Write(ex.Message);
  }
}
#endregion

推荐答案


这篇关于将数据导出为pdf时出现问题的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!

09-03 04:19