如何在C#.Net中生成显示SQL记录的PDF文件?

如何在C#.Net中生成显示SQL记录的PDF文件?,c#,.net,winforms,pdf-generation,C#,.net,Winforms,Pdf Generation,我正在开发一个库存管理系统(窗口窗体)。 我有一个.Net windows窗体,显示所有订单的列表(在dataGridView中)。 任务是提供打印或通过电子邮件发送订单详细信息的PDF版本的选项。它包含纯文本(如问候语)和SQL Server表中的值(如订单号、日期、项目列表) 我正试图找出做这件事的最佳方法 在用户选择订单时生成PDF,而不是为所有订单创建和保存PDF,这似乎是明智的。 但我正在努力寻找如何继续 这个问题太宽泛,而且是基于观点的。但通常很少有办法做到这一点 protected

我正在开发一个库存管理系统(窗口窗体)。 我有一个.Net windows窗体,显示所有订单的列表(在dataGridView中)。
任务是提供打印或通过电子邮件发送订单详细信息的PDF版本的选项。它包含纯文本(如问候语)和SQL Server表中的值(如订单号、日期、项目列表)

我正试图找出做这件事的最佳方法

在用户选择订单时生成PDF,而不是为所有订单创建和保存PDF,这似乎是明智的。
但我正在努力寻找如何继续

这个问题太宽泛,而且是基于观点的。但通常很少有办法做到这一点

protected void ExportToPDF(object sender, EventArgs e)
{
    //Get the data from database into datatable

    string strQuery = "select CustomerID, ContactName, City, PostalCode" +
        " from customers";
    SqlCommand cmd = new SqlCommand(strQuery);
    DataTable dt = GetData(cmd);

    //Create a dummy GridView

    GridView GridView1 = new GridView();
    GridView1.AllowPaging = false;
    GridView1.DataSource = dt;
    GridView1.DataBind();

    Response.ContentType = "application/pdf";
    Response.AddHeader("content-disposition",
        "attachment;filename=DataTable.pdf");
    Response.Cache.SetCacheability(HttpCacheability.NoCache);
    StringWriter sw = new StringWriter();
    HtmlTextWriter hw = new HtmlTextWriter(sw);
    GridView1.RenderControl(hw);
    StringReader sr = new StringReader(sw.ToString());
    Document pdfDoc = new Document(PageSize.A4, 10f, 10f, 10f, 0f);
    HTMLWorker htmlparser = new HTMLWorker(pdfDoc);
    PdfWriter.GetInstance(pdfDoc, Response.OutputStream);
    pdfDoc.Open();
    htmlparser.Parse(sr);
    pdfDoc.Close();
    Response.Write(pdfDoc);
    Response.End(); 
}
  • Excel互操作(甚至Word)-将数据加载到Excel,并调用Excel打印到pdf
  • 通常,Crystal Reports或其他报表库提供“另存为pdf”选项
  • 创建一个文件(任何格式)并使用pdf打印机,这是您安装并从代码调用的软件打印机。这种打印机是免费的
  • 使用像iTextSharp这样的专用库在代码中创建pdf
  • 毫无疑问,有这样的在线服务,您可以转换您的文件

  • 没有从.NET生成PDF的内置方法。您需要使用第三方库。进行一些研究以确定您要使用哪个库以及如何使用它。解决方案是安装一台(免费)Pdf打印机并将您的页面打印到此打印机。BullZip打印机允许您无需任何提示即可完成此操作。更多详细信息请参见。您应该解释这与Windows窗体的关系吗?