通過C#代碼輕松提取PDF文本
PDF格式因其跨平臺兼容性強、安全性高等特點而被廣泛使用。但PDF文檔不易編輯,因此提取PDF文檔的文本從而進行操作是一個常見的需求。提取PDF中的文本可以幫助我們對PDF文檔進行內(nèi)容再利用,從而制作新的PDF文檔或?qū)?nèi)容插入到其他格式的文檔中。在.NET平臺,我們可以使用簡單的C#代碼輕松實現(xiàn)PDF文檔文本的提取。
本文所使用的方法需要用到Free Spire.PDF for .NET,NuGet:PM> Install-Package FreeSpire.PDF
。
用C#提取PDF文本的操作步驟
庫中提供了PdfTextExtractor類來處理PDF文檔的文本提取。我們可以使用頁面創(chuàng)建PdfTextExtractor對象,然后使用PdfTextExtractor.ExtractText()方法來提取頁面文本。同時,PdfTextExtractOptions類能對提取選項進行設置,如設置是否保留布局和設置提取的頁面區(qū)域。以下是一般操作步驟。
創(chuàng)建PdfDocument對象。
使用PdfDocument.LoadFromFile()方法載入PDF文檔。
使用PdfDocument.Pages[]屬性獲取指定頁面,也可以遍歷所有頁面。
使用頁面創(chuàng)建PdfTextExtractor對象。
創(chuàng)建PdfTextExtractOptions對象并設置提取選項。
使用PdfTextExtractor.ExtractText(PdfTextExtractOptions)方法提取頁面文本。
將提取的文本寫入文件或用于其他用途。
釋放資源。
提取PDF文本不保留文本布局
如果需要不保留文本布局直接提取文本內(nèi)容,可以將PdfTextExtractOptions.IsSimpleExtraction屬性設置為true來實現(xiàn)。以下是代碼示例:
using Spire.Pdf; using Spire.Pdf.Texts; using System.Text; namespace ExtractPDFText { class Program { static void Main(string[] args) { // 創(chuàng)建PdfDocument對象 PdfDocument pdf = new PdfDocument(); // 載入PDF文檔 pdf.LoadFromFile("Sample.pdf"); // 創(chuàng)建PdfTextExtractOptions對象,并設置不保留布局 PdfTextExtractOptions extractOptions = new PdfTextExtractOptions(); extractOptions.IsSimpleExtraction = true; // 創(chuàng)建StringBuilder對象以儲存提取的文本 StringBuilder extractedText = new StringBuilder(); // 遍歷文檔頁面 foreach (PdfPageBase page in pdf.Pages) { // 使用頁面創(chuàng)建PdfTextExtractor對象 PdfTextExtractor extractor = new PdfTextExtractor(page); // 提取當前頁面的文本 string text = extractor.ExtractText(extractOptions); // 將提取到的文本添加到StringBuilder對象 extractedText.Append(text); } // 將提取結果寫入文本文件 using (StreamWriter writer = new StreamWriter("output/ExtractedPDFText.txt", false, Encoding.UTF8)) { writer.Write(extractedText.ToString()); } // 釋放資源 pdf.Close(); } } }
結果
保留文本布局提取PDF文本
如果在提取PDF文本時需要保留PDF文本的布局(使用空格填補),則可以直接使用默認的提取選項提取PDF文本。以下是代碼示例:
using Spire.Pdf; using Spire.Pdf.Texts; using System.Text; namespace ExtractPDFTextAndLayout { class Program { static void Main(string[] args) { // 創(chuàng)建PdfDocument對象 PdfDocument pdf = new PdfDocument(); // 載入PDF文檔 pdf.LoadFromFile("Sample.pdf"); // 創(chuàng)建文本提取選項 PdfTextExtractOptions extractOptions = new PdfTextExtractOptions(); // 創(chuàng)建StringBuilder對象以儲存提取的文本 StringBuilder extractedText = new StringBuilder(); // 遍歷文檔頁面 foreach (PdfPageBase page in pdf.Pages) { // 使用頁面創(chuàng)建PdfTextExtractor對象 PdfTextExtractor extractor = new PdfTextExtractor(page); // 提取當前頁面的文本 string text = extractor.ExtractText(extractOptions); // 將提取到的文本添加到StringBuilder對象 extractedText.Append(text); } // 將提取結果寫入文本文件 using (StreamWriter writer = new StreamWriter("output/ExtractedPDFText.txt", false, Encoding.UTF8)) { writer.Write(extractedText.ToString()); } // 釋放資源 pdf.Close(); } } }
結果
提取PDF頁面指定區(qū)域內(nèi)的文本
我們還可以通過PdfTextExtractOptions.ExtractArea屬性設置提取區(qū)域,從而實現(xiàn)提取頁面上指定區(qū)域內(nèi)的文本。以下是代碼示例:
using Spire.Pdf.Texts; using Spire.Pdf; using System.Drawing; using System.Text; namespace ExtractPDFTextArea { class Program { static void Main(string[] args) { // 創(chuàng)建PdfDocument對象 PdfDocument pdf = new PdfDocument(); // 載入PDF文檔 pdf.LoadFromFile("Sample.pdf"); // 獲取指定頁面 PdfPageBase page = pdf.Pages[0]; // 創(chuàng)建PdfTextExtractor對象 PdfTextExtractor extractor = new PdfTextExtractor(page); // 創(chuàng)建PdfTextExtractOptions對象 PdfTextExtractOptions extractOptions = new PdfTextExtractOptions(); // 設置要提取文本的矩形區(qū)域 extractOptions.ExtractArea = new RectangleF(80, 100, 250, 150); // 提取頁面上指定位置的文本 string extractedText = extractor.ExtractText(extractOptions); // 將提取的文本寫入文本文件 File.WriteAllText("output/ExtractPDFPageAreaText.txt", extractedText, Encoding.UTF8); // 釋放資源 pdf.Close(); } } }
結果
以上就是通過C#代碼輕松提取PDF文本的詳細內(nèi)容,更多關于C#提取PDF文本的資料請關注腳本之家其它相關文章!
相關文章
C#調(diào)用百度地圖API根據(jù)地名獲取經(jīng)緯度geocoding
本文主要介紹了C#調(diào)用百度地圖API根據(jù)地名獲取經(jīng)緯度geocoding,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-04-04