DocumentTextExtractor 1.0.9

There is a newer version of this package available.
See the version list below for details.
dotnet add package DocumentTextExtractor --version 1.0.9                
NuGet\Install-Package DocumentTextExtractor -Version 1.0.9                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="DocumentTextExtractor" Version="1.0.9" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add DocumentTextExtractor --version 1.0.9                
#r "nuget: DocumentTextExtractor, 1.0.9"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install DocumentTextExtractor as a Cake Addin
#addin nuget:?package=DocumentTextExtractor&version=1.0.9

// Install DocumentTextExtractor as a Cake Tool
#tool nuget:?package=DocumentTextExtractor&version=1.0.9                

documenttextextractor

DocumentTextExtractor

Simple C# library for extracting text and metadata from .docx, .pptx, and .xlsx files

NuGet Version NuGet

DocumentTextExtractor provides simple methods for extracting text and metadata from .docx, .pptx, and .xlsx files.

New in v1.0.x

  • Initial release
  • Support for docx, pptx, xlsx, and pdf

Disclaimer

This library has been tested on a limited set of documents. It is highly likely that documents exist this from which the library, in its current state, cannot extract text.

The PDF implementation relies upon PDFSharp and PDFPlumber. The latter is written in Python and requires that you have installed Python and used pip to install the pdfplumber package.

Simple Examples

Refer to the Test project for a full example.

using DocumentTextExtractor;

void Main(string[] args)
{
  using (DocxTextExtractor docx = new DocxTextExtractor("./temp/", "mydocument.docx"))
  {
    string docxText = docx.ExtractText();
    Dictionary<string, string> docxMetadata = docx.ExtractMetadata();
  }

  using (PptxTextExtractor pptx = new PptxTextExtractor("./temp/", "mypresentation.pptx"))
  {
    string pptxText = pptx.ExtractText();
    Dictionary<string, string> pptxMetadata = pptx.ExtractMetadata();
  }

  using (XlsxTextExtractor xlsx = new XlsxTextExtractor("./temp/", "myspreadsheet.xlsx"))
  {
    string xlsxText = xlsx.ExtractText();
    Dictionary<string, string> xlsxMetadata = xlsx.ExtractMetadata();
  }

  using (PdfTextExtractor pdf = new PdfTextExtractor("myfile.pdf"))
  {
    string pdfText = pdf.ExtractText();
    Dictionary<string, string> pdfMetadata = pdf.ExtractMetadata();
  }
}

Contextual Extraction

For certain document types (e.g. pptx and xlsx) text can be extracted with an identifier for the slide or sheet number associated with the document.

using (PptxTextExtractor pptx = new PptxTextExtractor("./temp/", "mypresentation.pptx"))
{
  IEnumerable<KeyValuePair<int, string>> slideContent = pptx.ExtractTextBySlide();
  foreach (KeyvaluePair<int, string> kvp in slideContent)
  {
    Console.WriteLine("Slide " + kvp.Key + ": " + kvp.Value);
  }
}

using (XlsxTextExtractor xlsx = new XlsxTextExtractor("./temp/", "mypresentation.pptx"))
{
  IEnumerable<KeyValuePair<int, string>> sheetContent = xlsx.ExtractTextBySheet();
  foreach (KeyvaluePair<int, string> kvp in sheetContent)
  {
    Console.WriteLine("Sheet " + kvp.Key + ": " + kvp.Value);
  }
}

Version History

Please refer to CHANGELOG.md.

Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 is compatible.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.0.10 114 10/5/2024
1.0.9 109 7/25/2024
1.0.8 132 3/27/2024
1.0.7 127 3/27/2024
1.0.6 117 3/27/2024
1.0.5 115 3/27/2024
1.0.4 115 3/26/2024
1.0.3 1,614 8/11/2023

Initial release