亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

通過C#代碼輕松提取PDF文本

 更新時間:2024年11月21日 08:36:59   作者:Eiceblue  
提取PDF中的文本可以幫助我們對PDF文檔進行內(nèi)容再利用,從而制作新的PDF文檔或?qū)?nèi)容插入到其他格式的文檔中,下面我們就來看看如何使用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文本的資料請關注腳本之家其它相關文章!

相關文章

最新評論