如何在 C#.Net 中生成显示 SQL 条记录的 PDF 文件?
How do I generate a PDF file in C#.Net that displays SQL records?
我正在开发一个库存管理系统(Window 表格)。
我有一个 .Net windows 表单 ,它显示所有订单的列表( 在 dataGridView 中)。
任务是提供打印或通过电子邮件发送订单详细信息的 PDF 版本的选项。它包含纯文本(例如问候语)和来自 SQL 服务器表的值(例如订单号、日期、项目列表)
我正在尝试找出最好的方法。
当用户选择订单时生成 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 报告或其他报告库会提供 "save as pdf" 选项。
- 创建文件(任何格式)并使用 pdf 打印机,这是您安装并从代码调用的软件打印机。有免费的此类打印机。
- 使用像 iTextSharp 这样的专业库在代码中创建您的 pdf
- 毫无疑问 - 有这样的在线服务可以转换您的文件
我正在开发一个库存管理系统(Window 表格)。
我有一个 .Net windows 表单 ,它显示所有订单的列表( 在 dataGridView 中)。
任务是提供打印或通过电子邮件发送订单详细信息的 PDF 版本的选项。它包含纯文本(例如问候语)和来自 SQL 服务器表的值(例如订单号、日期、项目列表)
我正在尝试找出最好的方法。
当用户选择订单时生成 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 报告或其他报告库会提供 "save as pdf" 选项。
- 创建文件(任何格式)并使用 pdf 打印机,这是您安装并从代码调用的软件打印机。有免费的此类打印机。
- 使用像 iTextSharp 这样的专业库在代码中创建您的 pdf
- 毫无疑问 - 有这样的在线服务可以转换您的文件