DocumentTextExtractor 1.0.10
dotnet add package DocumentTextExtractor --version 1.0.10
NuGet\Install-Package DocumentTextExtractor -Version 1.0.10
<PackageReference Include="DocumentTextExtractor" Version="1.0.10" />
paket add DocumentTextExtractor --version 1.0.10
#r "nuget: DocumentTextExtractor, 1.0.10"
// Install DocumentTextExtractor as a Cake Addin #addin nuget:?package=DocumentTextExtractor&version=1.0.10 // Install DocumentTextExtractor as a Cake Tool #tool nuget:?package=DocumentTextExtractor&version=1.0.10
DocumentTextExtractor
Simple C# library for extracting text and metadata from .docx, .pptx, and .xlsx files
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
, andpdf
- Contextual extraction for
pptx
,xlsx
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 | Versions 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. |
-
net6.0
- PDFsharp (>= 6.1.1)
- Shelli (>= 2.0.0)
- System.Text.Json (>= 8.0.4)
- XmlToPox (>= 1.0.3)
-
net7.0
- PDFsharp (>= 6.1.1)
- Shelli (>= 2.0.0)
- System.Text.Json (>= 8.0.4)
- XmlToPox (>= 1.0.3)
-
net8.0
- PDFsharp (>= 6.1.1)
- Shelli (>= 2.0.0)
- System.Text.Json (>= 8.0.4)
- XmlToPox (>= 1.0.3)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Initial release