将gridview转换为itextsharp表并使用asp.net生成pdf

时间:2013-12-13 10:38:28

标签: c# asp.net pdf gridview itextsharp

这里我试图将GridView转换为PDF,当转换PDF时没有获得PDF格式的GridView列宽。所以我使用另一种方法生成PDF(即)从GridView创建的itextsharp表。这里我得到了列宽大小我在GridView列中给出ItemStyle-Width.But我已经在GridView中完成了分组列,所以我没有在PDF中获得具有相同列宽的完整GridView。任何人都请帮助我。

这是来源:

<asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" 
     onsorting="GridView1_Sorting">
     <HeaderStyle BackColor="#4F81BD" Font-Bold="true" ForeColor="#ffffff" HorizontalAlign="Center" Font-Size="12px"/>
    <AlternatingRowStyle BackColor="#D3DFEE" />
    <RowStyle />
    <Columns>
         <asp:BoundField DataField="Category" HeaderText="Category"
            SortExpression="Category" ItemStyle-Width="100px"/>
            <asp:BoundField DataField="Partno" HeaderText="Partno" 
             ItemStyle-Width="100px"/>
            <asp:BoundField DataField="Productname" HeaderText="Productname" 
             ItemStyle-Width="300px"/>
            <asp:BoundField DataField="Brand" HeaderText="Brand" 
            ItemStyle-Width="100px"/>
            <asp:BoundField DataField="Qty" HeaderText="Qty" 
             ItemStyle-Width="50px"/>
            <asp:BoundField DataField="Unitprice" HeaderText="Unitprice" 
             ItemStyle-Width="50px"/>
            <asp:BoundField DataField="Totalprice" HeaderText="Totalprice" 
             ItemStyle-Width="50px"/>
    </Columns>

</asp:GridView>  

这是分组的gridview:

enter image description here

这是将gridview转换为itextsharp表并生成PDF的代码:

//Create a table
iTextSharp.text.Table table = new iTextSharp.text.Table(GridView1.Columns.Count);
table.Cellpadding = 5;
//Set the column widths
int[] widths = new int[GridView1.Columns.Count];
for (int x = 0; x < GridView1.Columns.Count; x++)
{
    widths[x] = (int)GridView1.Columns[x].ItemStyle.Width.Value;
    string cellText = Server.HtmlDecode(GridView1.HeaderRow.Cells[x].Text);
    iTextSharp.text.Cell cell = new iTextSharp.text.Cell(cellText);
    cell.BackgroundColor = new iTextSharp.text.Color(System.Drawing.ColorTranslator.FromHtml("#008000"));
    table.AddCell(cell);
}

table.SetWidths(widths);
//Transfer rows from GridView to table

for (int i = 0; i < GridView1.Rows.Count; i++)
{
    if (GridView1.Rows[i].RowType == DataControlRowType.DataRow)
    {
        for (int j = 0; j < GridView1.Columns.Count; j++)
        {
            string cellText = Page.Server.HtmlDecode(GridView1.Rows[i].Cells[j].Text);
            iTextSharp.text.Cell cell = new iTextSharp.text.Cell(cellText);

            //Set Color of Alternating row
            if (i % 2 != 0)
            {
                cell.BackgroundColor = new iTextSharp.text.Color(System.Drawing.ColorTranslator.FromHtml("#C2D69B"));
            }

            table.AddCell(cell);
        }
    }
}

//Create the PDF Document

Document pdfDoc = new Document(PageSize.A4, 10f, 10f, 10f, 0f);
PdfWriter.GetInstance(pdfDoc, Response.OutputStream);
pdfDoc.Open();
pdfDoc.Add(table);
pdfDoc.Close();
Response.ContentType = "application/pdf";
Response.AddHeader("content-disposition", "attachment;" +
                               "filename=GridViewExport.pdf");
Response.Cache.SetCacheability(HttpCacheability.NoCache);
Response.Write(pdfDoc);
Response.End();

这是PDF:

enter image description here

我希望精确的gridview在PDF中具有相同的列宽。

2 个答案:

答案 0 :(得分:2)

PdfPTable默认使用相对宽度。当您说table.SetWidths(widths) iText汇总widths并将每个宽度除以该总和以获得百分比时。因此1, 2, 310, 20, 30甚至2, 4, 6相同。您希望使用SetTotalWidth(widths)以及设置LockedWidth = true强制绝对宽度。

table.SetTotalWidth(widths);
table.LockedWidth = true;

然而,这样做声明您现在已经知道并控制了表格的水平布局。如果你横向溢出页面,你将不会得到任何包装,事情就会被切断。您还声明如果需要,可以接受边际空间。

答案 1 :(得分:0)

这应该可以解决问题:

GridView1.AllowPaging = False