欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C#實現(xiàn)從Word文檔和各種Word元素中自動提取文本

 更新時間:2025年11月07日 09:42:47   作者:SunnyDays1011  
手動提取文本既費時又容易出錯,尤其是在處理較長或復雜的Word文檔時,這篇文章將探討如何使用C# 從Word文檔中提取文本,我們將涵蓋不同方面的內容,希望對大家有所幫助

Word文檔在我們的日常生活中占據(jù)著重要位置,無論是在商業(yè)、教育還是政府工作中,都經(jīng)常需要處理它們。有時,我們需要從這些文檔中提取文本以便在其他地方使用。例如,從法律文件中提取特定章節(jié)進行審查,從報告中提取數(shù)據(jù)以納入演示文稿,或從會議紀要中提取要點與團隊分享。

手動提取文本既費時又容易出錯,尤其是在處理較長或復雜的Word文檔時。自動化這個過程不僅能節(jié)省時間,還能確保準確性。這篇文章將探討如何使用C# 從Word文檔中提取文本。我們將涵蓋不同方面的內容,如提取整個Word文檔的文本、以及提取特定章節(jié)、頁面、段落、行,甚至表格、頁眉和頁腳中的文本。

使用工具

要使用 C# 從 Word 文檔和各種Word元素中提取文本,可以利用 Spire.Doc for .NET 庫。

Spire.Doc for .NET 介紹

Spire.Doc for .NET 是一個功能強大的庫,用于在各種 .NET 框架中處理 Word 文檔,包括 C#、VB.NET、ASP.NET 和 .NET Core。它支持 Word 文件的創(chuàng)建、讀取、編輯、打印和轉換。支持多種 Word 格式,如 DOC、DOCX、DOCM、DOT、DOTX 和 DOTM。此外,它還支持將 Word 文檔轉換為常見格式,如 PDF、RTF、HTML、Text、Image、SVG、ODT、PostScript、PCL 和 XPS。

安裝步驟

安裝 Spire.Doc for .NET 有兩種主要方式:

1. NuGet 安裝

在 Visual Studio 中,右鍵單擊項目中的“解決方案資源管理器”,選擇“管理 NuGet 包”,搜索 Spire.Doc,然后點擊“安裝”?;蛘?,你也可以在“包管理器控制臺”中運行以下命令:

Install-Package Spire.Doc

2. 手動安裝

如果你更喜歡手動安裝,可以從官方網(wǎng)站下載 Spire.Doc 庫。下載后,將 DLL 文件引用添加到項目中。右鍵單擊“解決方案資源管理器”中的“引用”節(jié)點,選擇“添加引用”,瀏覽到下載的 Spire.Doc DLL 的位置,然后將其添加到項目中。

C# 從Word文檔中提取文本

提取Word文檔中的所有文本是文檔處理任務中的常見需求,該需求可以通過Document類的GetText方法來實現(xiàn),它會將文檔中的所有文本內容返回為字符串。之后,你可以將該字符串的內容寫入文本文件。

實現(xiàn)步驟:

  • 使用Document類打開文檔。
  • 使用Document對象的GetText方法提取所有文本內容。
  • 將提取的文本保存到文本文件中。

以下是使用C# 從Word文檔中提取所有文本的代碼:

using Spire.Doc;
using System.IO;

namespace ExtractTextFromDocument
{
    internal class Program
    {
        static void Main(string[] args)
        {
            // 打開Word文檔
            Document document = new Document("示例.docx");

            // 提取文檔的文本
            string documentText = document.GetText();

            // 將提取的文本寫入文本文件
            File.WriteAllText("Output/文檔文本.txt", documentText);

            document.Close();
        }
    }
}

C# 從Word文檔中提取特定章節(jié)的文本

Word文檔可能包含多個章節(jié),每個章節(jié)都有獨特的內容或格式。要從特定章節(jié)提取文本,可以按以下步驟操作:

  • 使用Document類打開文檔。
  • 從Document對象的Sections集合中獲取特定章節(jié)。
  • 遍歷Section對象的Paragraphs集合。
  • 使用Paragraph.Text屬性獲取章節(jié)中每個段落的文本內容。
  • 將提取的內容保存到文本文件中。

以下是使用C# 從Word文檔中提取章節(jié)文本的代碼:

using Spire.Doc;
using Spire.Doc.Documents;
using System.IO;
using System.Text;

namespace ExtractTextFromSection
{
    internal class Program
    {
        static void Main(string[] args)
        {
            // 打開Word文檔
            Document document = new Document("示例.docx");

            // 獲取文檔中的第一個章節(jié)(可以根據(jù)需要更改索引)
            Section section = document.Sections[0];

            // 創(chuàng)建StringBuilder存儲提取的文本
            StringBuilder sectionText = new StringBuilder();

            // 遍歷章節(jié)中的段落
            foreach (Paragraph paragraph in section.Paragraphs)
            {
                // 將每個段落的文本添加到StringBuilder中
                sectionText.Append(paragraph.Text + "\n");
            }

            // 將StringBuilder中的內容寫入文本文件
            File.WriteAllText("Output/章節(jié)文本.txt", sectionText.ToString());

            document.Close();
        }
    }
}

C# 從Word文檔中提取特定段落的文本

有時,你可能只想從Word文檔中的某一段落提取文本。要實現(xiàn)該功能,可以按照以下步驟操作:

  • 使用Document類打開文檔。
  • 從Document對象的Sections集合中獲取特定章節(jié)。
  • 從Section對象的Paragraphs集合中獲取特定段落。
  • 使用Paragraph.Text屬性獲取該段落的文本內容。
  • 將提取的內容保存到文本文件中。

以下是使用C# 從Word文檔中提取特定段落文本的代碼:

using Spire.Doc;
using Spire.Doc.Documents;
using System.IO;

namespace ExtractTextFromParagraph
{
    internal class Program
    {
        static void Main(string[] args)
        {
            // 打開Word文檔
            Document document = new Document("示例.docx");

            // 獲取文檔中的第一個章節(jié)(可以根據(jù)需要更改索引)
            Section section = document.Sections[0];

            // 獲取章節(jié)中的第二個段落(可以根據(jù)需要更改索引)
            Paragraph paragraph = section.Paragraphs[1];

            // 提取段落的文本
            string paraText = paragraph.Text;

            // 將提取的文本寫入文本文件
            File.WriteAllText("Output/段落.txt", paraText);

            document.Close();
        }
    }
}

C# 從Word文檔中提取特定頁面的文本

有時候,你可能需要提取 Word 文檔中特定頁面的內容。然而,Word 文檔是基于流的,它并不像 PDF 文件那樣本身有頁面的概念。要進行頁面級文本提取,必須先將 Word 文檔轉換為固定布局。以下是實現(xiàn)步驟:

  • 使用 FixedLayoutDocument 類將 Word 文檔轉換為固定布局文檔。
  • 從 FixedLayoutDocument 對象的 Pages 集合獲取所需頁面。
  • 使用 FixedLayoutPage 對象的 Text 屬性提取頁面文本。
  • 將提取的文本保存到文本文件中。

以下是使用 C# 從 Word 文檔中提取特定頁面文本的實現(xiàn)代碼:

using Spire.Doc;
using Spire.Doc.Pages;
using System.IO;

namespace ExtractTextFromPage
{
    internal class Program
    {
        static void Main(string[] args)
        {
            // 打開 Word 文檔
            Document document = new Document("示例.docx");

            // 將文檔轉換為固定布局文檔以執(zhí)行頁面級操作
            FixedLayoutDocument fixedLayoutDoc = new FixedLayoutDocument(document);

            // 獲取文檔中的第一頁(可以根據(jù)需要更改索引)
            var page = fixedLayoutDoc.Pages[0];

            // 獲取該頁面的文本
            string pageText = page.Text;

            // 將提取的文本寫入文本文件
            File.WriteAllText("Output/頁面文本.txt", pageText);

            document.Close();
        }
    }
}

C# 從 Word 文檔中提取特定行的文本

在 Word 中,行是文本在頁面或列中的可視化排列單位,并非獨立的結構對象,其顯示方式受段落、換行符和頁面布局的影響。要從 Word 中提取行文本,同樣需要將Word文檔轉換為固定布局。以下是實現(xiàn)步驟:

  • 使用 FixedLayoutDocument 類將 Word 文檔轉換為固定布局文檔。
  • 從 FixedLayoutDocument 對象的 Pages 集合獲取所需頁面。
  • 從頁面的 Columns 集合中獲取特定列(Word文檔可以包含多列),然后從該列的 Lines 集合中獲取特定行。
  • 使用該行的 Text 屬性提取其內容。
  • 將提取的文本保存到文本文件中。

以下是使用 C# 從 Word 文檔中提取特定行文本的實現(xiàn)代碼:

using Spire.Doc;
using Spire.Doc.Documents;
using Spire.Doc.Pages;
using System.IO;
using System.Text;

namespace ExtractTextFromLine
{
    internal class Program
    {
        static void Main(string[] args)
        {
            // 打開 Word 文檔
            Document document = new Document("示例.docx");

            // 將文檔轉換為固定布局文檔以執(zhí)行頁面級操作
            FixedLayoutDocument fixedLayoutDoc = new FixedLayoutDocument(document);

            // 假設我們要提取第一頁的第一行
            // 獲取第一頁
            var page = fixedLayoutDoc.Pages[0];
            // 獲取第一列
            var column = page.Columns[0];
            // 獲取第一行
            var line = column.Lines[0];

            // 提取該行的文本
            string lineText = line.Text;

            // 將提取的文本寫入文本文件
            File.WriteAllText("Output/行文本.txt", lineText);

            document.Close();
        }
    }
}

C# 從 Word 文檔中提取特定表格的文本

Word 文檔中的表格通過行和列組織信息,使其更易于理解。提取這些表格中的數(shù)據(jù)有助于對這些信息進行進一步分析和處理。以下是提取Word文檔中表格數(shù)據(jù)的實現(xiàn)步驟:

  • 使用Document類打開文檔。
  • 從Document對象的Sections集合中獲取包含表格的章節(jié)。
  • 從Section的 Tables 集合中獲取特定表格。
  • 遍歷表格中的行、單元格和單元格中的段落。
  • 使用 Paragraph.Text 屬性提取每個段落的文本。
  • 將提取的數(shù)據(jù)保存為文本文件,并格式化(例如,使用制表符分隔)。

以下是使用 C# 從 Word 文檔中提取特定表格數(shù)據(jù)的實現(xiàn)代碼:

using Spire.Doc;
using Spire.Doc.Documents;
using System.IO;
using System.Text;

namespace ExtractTextFromTable
{
    internal class Program
    {
        static void Main(string[] args)
        {
            // 打開 Word 文檔
            Document document = new Document("表格.docx");

            // 獲取文檔中的第一節(jié)
            Section section = document.Sections[0];

            // 獲取該節(jié)中的第一個表格
            Table table = section.Tables[0] as Table;

            // 創(chuàng)建 StringBuilder 用于存儲表格數(shù)據(jù)
            StringBuilder tableData = new StringBuilder();

            // 遍歷表格中的行
            foreach (TableRow row in table.Rows)
            {
                // 遍歷每一行中的單元格
                foreach (TableCell cell in row.Cells)
                {
                    // 遍歷單元格中的段落
                    foreach (Paragraph paragraph in cell.Paragraphs)
                    {
                        // 將每個段落的文本添加到 StringBuilder
                        tableData.Append(paragraph.Text + "\t");
                    }
                }
                tableData.Append("\n");
            }

            // 將 StringBuilder 中的內容寫入文本文件
            File.WriteAllText("Output/表格數(shù)據(jù).txt", tableData.ToString());

            document.Close();
        }
    }
}

C# 從 Word 文檔提取頁眉和頁腳文本

頁眉和頁腳通常包含文檔的標題、元數(shù)據(jù)等附加信息。提取這些信息,有助于更好地理解文檔內容。以下是提取Word文檔頁眉和頁腳文本內容的實現(xiàn)步驟:

  • 使用Document類打開文檔。
  • 從Document對象的Sections集合中獲取特定的章節(jié)。
  • 從Section的HeadersFooters集合中分別獲取 Header 和 Footer 對象。
  • 遍歷 Header 和 Footer 對象中的段落,并使用 Paragraph.Text 屬性提取段落文本。
  • 將提取的文本保存到文本文件中。

以下是使用 C# 從 Word 文檔中提取頁眉和頁腳文本的實現(xiàn)代碼:

using Spire.Doc;
using Spire.Doc.Documents;
using System.IO;
using System.Text;

namespace ExtractTextFromHeaderFooter
{
    internal class Program
    {
        static void Main(string[] args)
        {
            // 打開 Word 文檔
            Document document = new Document("頁眉頁腳.docx");

            // 獲取文檔中的第一節(jié)
            Section section = document.Sections[0];

            // 獲取該節(jié)的頁眉
            HeaderFooter header = section.HeadersFooters.Header;

            // 獲取該節(jié)的頁腳
            HeaderFooter footer = section.HeadersFooters.Footer;

            // 創(chuàng)建 StringBuilder 用于存儲提取的頁眉和頁腳文本
            StringBuilder headerFooterText = new StringBuilder();
            headerFooterText.Append("頁眉文本:\n");

            // 遍歷頁眉中的段落
            foreach (Paragraph paragraph in header.Paragraphs)
            {
                // 將每個段落的文本添加到 StringBuilder
                headerFooterText.Append(paragraph.Text + "\n");
            }

            headerFooterText.Append("頁腳文本:\n");

            // 遍歷頁腳中的段落
            foreach (Paragraph paragraph in footer.Paragraphs)
            {
                // 將每個段落的文本添加到 StringBuilder
                headerFooterText.Append(paragraph.Text + "\n");
            }

            // 將 StringBuilder 中的內容寫入文本文件
            File.WriteAllText("Output/頁眉頁腳文本.txt", headerFooterText.ToString());

            document.Close();
        }
    }
}

補充:除以上元素外,你還可以從其他Word元素例如批注和文本框中提取文本內容,由于篇幅問題,本文就不進行介紹了。

到此這篇關于C#實現(xiàn)從Word文檔和各種Word元素中自動提取文本的文章就介紹到這了,更多相關C#提取word文本內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

最新評論