一、itext
我要使用itext做一個pdf的頁面大小一致性處理,然後再根據資料切分出需要的pdf.
iText的官網有關於它的介紹,https://itextpdf.com/ 然後在官網可以查詢api文件https://api.itextpdf.com/。
其中我要使用的是itext7+,主要在iText.Kernel.Pdf
名稱空間下。
二、處理PDF頁面大小一致
由於原始PDF 是掃描圖片合成來的,有些頁面掃描的圖片規格不一致,導致pdf閱讀性很差。
對於這個pdf我進行處理,首先是在nuget 裡面搜尋 itext 進行安裝,使用itext7。
處理PDF大小方法:
public void RestPageSize(string sourcePdfPath, string outputPdfPath)
{
PdfReader pdfReader = null;
PdfDocument pdfDocument = null;
PdfWriter pdfWriter = null;
PdfDocument outPDfDoc = null;
try
{
pdfReader = new PdfReader(sourcePdfPath);
pdfDocument = new PdfDocument(pdfReader);
var outDir = System.IO.Path.GetDirectoryName(outputPdfPath);
if (!Directory.Exists(outDir))
{
Directory.CreateDirectory(outDir);
}
pdfWriter = new PdfWriter(outputPdfPath);
outPDfDoc = new PdfDocument(pdfWriter);
outPDfDoc.SetDefaultPageSize(PageSize.A3);
for (int i = 1; i < pdfDocument.GetNumberOfPages() + 1; i++)
{
var page = pdfDocument.GetPage(i);
var formXObject = page.CopyAsFormXObject(outPDfDoc);
var xPercent = PageSize.A3.GetWidth() / page.GetPageSize().GetWidth();
var yPercent = PageSize.A3.GetHeight() / page.GetPageSize().GetHeight();
PdfCanvas pdfCanvas = new PdfCanvas(outPDfDoc.AddNewPage());
pdfCanvas.AddXObjectWithTransformationMatrix(formXObject, xPercent, 0, 0, yPercent, 0, 0);
}
pdfWriter.Flush();
}
catch (Exception ex)
{
Console.WriteLine(ex);
}
finally
{
if (pdfReader != null)
{
pdfReader.Close();
}
if (pdfDocument != null)
{
pdfDocument.Close();
}
if (outPDfDoc != null)
{
outPDfDoc.Close();
}
if (pdfWriter != null)
{
pdfWriter.Close();
pdfWriter.Dispose();
}
}
思路:遍歷原來的PDF頁碼,將原來的PDF頁碼物件拷貝PdfFormXObject
到要生成的PDF文件中,首先要copy頁面物件才能使用,不然直接獲取的page物件是原來文件的,我們無法操作。
var formXObject = page.CopyAsFormXObject(outPDfDoc);
然後對頁面進行縮放計算,我們新的PDF預設設定成A3大小,通過計算原始頁面和新頁面寬高比例進行縮放。
計算完成後,在新文件中使用PdfCanvas
物件新新增一頁,然後將PdfFormXObject
寫入到新新增的頁中。
處理後的PDF:
三、切分PDF
切分PDF 就比較簡單了,直接從原始檔案中拷貝頁面到新PDF文件中就行了。
切分PDF 方法:
public void ExtractPages(string sourcePdfPath, string outputPdfPath, int startPage, int endPage)
{
PdfReader pdfReader = null;
PdfDocument pdfDocument = null;
PdfWriter pdfWriter = null;
PdfDocument outPDfDoc = null;
try
{
pdfReader = new PdfReader(sourcePdfPath);
pdfDocument = new PdfDocument(pdfReader);
var outDir = Path.GetDirectoryName(outputPdfPath);
if (!Directory.Exists(outDir))
{
Directory.CreateDirectory(outDir);
}
pdfWriter = new PdfWriter(outputPdfPath);
outPDfDoc = new PdfDocument(pdfWriter);
pdfDocument.CopyPagesTo(startPage, endPage, outPDfDoc);
pdfWriter.Flush();
}
catch (Exception ex)
{
Console.WriteLine(ex);
}
finally
{
if (pdfReader != null)
{
pdfReader.Close();
}
if (pdfDocument != null)
{
pdfDocument.Close();
}
if (outPDfDoc != null)
{
outPDfDoc.Close();
}
if (pdfWriter != null)
{
pdfWriter.Close();
pdfWriter.Dispose();
}
}
}
注意:對寫入流要進行pdfWriter.Flush()
將緩衝區資料寫入PDF後再關。