PdfPig 0.1.1-alpha001

This is a prerelease version of PdfPig.
There is a newer version of this package available.
See the version list below for details.
dotnet add package PdfPig --version 0.1.1-alpha001                
NuGet\Install-Package PdfPig -Version 0.1.1-alpha001                
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="PdfPig" Version="0.1.1-alpha001" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add PdfPig --version 0.1.1-alpha001                
#r "nuget: PdfPig, 0.1.1-alpha001"                
#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 PdfPig as a Cake Addin
#addin nuget:?package=PdfPig&version=0.1.1-alpha001&prerelease

// Install PdfPig as a Cake Tool
#tool nuget:?package=PdfPig&version=0.1.1-alpha001&prerelease                

PdfPig

This project allows users to read and extract text and other content from PDF files. In addition the library can be used to create simple PDF documents containing text and geometrical shapes.

This project aims to port PDFBox to C#.

Get Started

The simplest usage at this stage is to open a document, reading the words from every page:

using (PdfDocument document = PdfDocument.Open(@"C:\Documents\document.pdf"))
{
    for (var i = 0; i < document.NumberOfPages; i++)
    {
        // This starts at 1 rather than 0.
        var page = document.GetPage(i + 1);

        foreach (var word in page.GetWords())
        {
            Console.WriteLine(word.Text);
        }
    }
}

New in v0.0.5 - To create documents use the class PdfDocumentBuilder. Though they are deprecated within the PDF specification the Standard 14 fonts provide a quick way to get started:

PdfDocumentBuilder builder = new PdfDocumentBuilder();

PdfPageBuilder page = builder.AddPage(PageSize.A4);

// Fonts must be registered with the document builder prior to use to prevent duplication.
PdfDocumentBuilder.AddedFont font = builder.AddStandard14Font(Standard14Font.Helvetica);

page.AddText("Hello World!", 12, new PdfPoint(25, 520), font);

byte[] documentBytes = builder.Build();

File.WriteAllBytes(@"C:\git\newPdf.pdf");

Each font must be registered with the PdfDocumentBuilder prior to use enable pages to share the font resources. Currently only Standard 14 fonts and TrueType fonts (.ttf) are supported.

Usage

The PdfDocument class provides access to the contents of a document loaded either from file or passed in as bytes. To open from a file use the PdfDocument.Open static method:

using UglyToad.PdfPig;
using UglyToad.PdfPig.Content;

using (PdfDocument document = PdfDocument.Open(@"C:\my-file.pdf"))
{
    int pageCount = document.NumberOfPages;

    Page page = document.GetPage(1);

    decimal widthInPoints = page.Width;
    decimal heightInPoints = page.Height;

    string text = page.Text;
}

The document contains the version of the PDF specification it complies with, accessed by document.Version:

decimal version = document.Version;

Document Creation

New in v0.0.5 - The PdfDocumentBuilder creates a new document with no pages or content. First, for text content, a font must be registered with the builder. Currently this supports Standard 14 fonts provided by Adobe by default and TrueType format fonts.

To add a Standard 14 font use:

public AddedFont AddStandard14Font(Standard14Font type)

Or for a TrueType font use:

AddedFont AddTrueTypeFont(IReadOnlyList<byte> fontFileBytes)

Passing in the bytes of a TrueType file (.ttf). You can check the suitability of a TrueType file for embedding in a PDF document using:

bool CanUseTrueTypeFont(IReadOnlyList<byte> fontFileBytes, out IReadOnlyList<string> reasons)

Which provides a list of reasons why the font cannot be used if the check fails. You should check the license for a TrueType font prior to use, since the compressed font file is embedded in, and distributed with, the resultant document.

The AddedFont class represents a key to the font stored on the document builder. This must be provided when adding text content to pages. To add a page to a document use:

PdfPageBuilder AddPage(PageSize size, bool isPortrait = true)

This creates a new PdfPageBuilder with the specified size. The first added page is page number 1, then 2, then 3, etc. The page builder supports adding text, drawing lines and rectangles and measuring the size of text prior to drawing.

To draw lines and rectangles use the methods:

void DrawLine(PdfPoint from, PdfPoint to, decimal lineWidth = 1)
void DrawRectangle(PdfPoint position, decimal width, decimal height, decimal lineWidth = 1)

The line width can be varied and defaults to 1. Rectangles are unfilled and the fill color cannot be changed at present.

To write text to the page you must have a reference to an AddedFont from the methods on PdfDocumentBuilder as described above. You can then draw the text to the page using:

IReadOnlyList<Letter> AddText(string text, decimal fontSize, PdfPoint position, PdfDocumentBuilder.AddedFont font)

Where position is the baseline of the text to draw. Currently only ASCII text is supported. You can also measure the resulting size of text prior to drawing using the method:

IReadOnlyList<Letter> MeasureText(string text, decimal fontSize, PdfPoint position, PdfDocumentBuilder.AddedFont font)

Which does not change the state of the page, unlike AddText.

Changing the RGB color of text, lines and rectangles is supported using:

void SetStrokeColor(byte r, byte g, byte b)
void SetTextAndFillColor(byte r, byte g, byte b)

Which take RGB values between 0 and 255. The color will remain active for all operations called after these methods until reset is called using:

void ResetColor()

Which resets the color for stroke, fill and text drawing to black.

Document Information

The PdfDocument provides access to the document metadata as DocumentInformation defined in the PDF file. These tend not to be provided therefore most of these entries will be null:

PdfDocument document = PdfDocument.Open(fileName);

// The name of the program used to convert this document to PDF.
string producer = document.Information.Producer;

// The title given to the document
string title = document.Information.Title;
// etc...

Document Structure

New in 0.0.3 the document now has a Structure member:

UglyToad.PdfPig.Structure structure = document.Structure;

This provides access to tokenized PDF document content:

Catalog catalog = structure.Catalog;
DictionaryToken pagesDictionary = catalog.PagesDictionary;

Page

The Page contains the page width and height in points as well as mapping to the PageSize enum:

PageSize size = Page.Size;

bool isA4 = size == PageSize.A4;

Page provides access to the text of the page:

string text = page.Text;

There is a new (0.0.3) method which provides access to the words. This uses basic heuristics and is not reliable or well-tested:

IEnumerable<Word> words = page.GetWords();

You can also (0.0.6) access the raw operations used in the page's content stream for drawing graphics and content on the page:

IReadOnlyList<IGraphicsStateOperation> operations = page.Operations;

There is also an early access (0.0.3) API for retrieving the raw bytes of PDF image objects per page:

IEnumerable<XObjectImage> images = page.ExperimentalAccess.GetRawImages();

This API will be changed in future releases.

Letter

Due to the way a PDF is structured internally the page text may not be a readable representation of the text as it appears in the document. Since PDF is a presentation format, text can be drawn in any order, not necessarily reading order. This means spaces may be missing or words may be in unexpected positions in the text.

To help users resolve actual text order on the page, the Page file provides access to a list of the letters:

IReadOnlyList<Letter> letters = page.Letters;

Credit

This project wouldn't be possible without the work done by the PDFBox team and the Apache Foundation. Any bugs in the code are entirely my fault.

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  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 was computed.  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 was computed.  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. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 was computed. 
.NET Framework net45 is compatible.  net451 is compatible.  net452 is compatible.  net46 is compatible.  net461 is compatible.  net462 is compatible.  net463 was computed.  net47 is compatible.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen40 was computed.  tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (47)

Showing the top 5 NuGet packages that depend on PdfPig:

Package Downloads
Microsoft.KernelMemory.Core

The package contains the the core logic and abstractions of Kernel Memory, not including extensions.

OrchardCore.Application.Cms.Core.Targets

Orchard Core CMS is a Web Content Management System (CMS) built on top of the Orchard Core Framework. Converts the application into a modular OrchardCore CMS application with TheAdmin theme but without any front-end Themes.

OrchardCore.Application.Cms.Targets

Orchard Core CMS is a Web Content Management System (CMS) built on top of the Orchard Core Framework. Converts the application into a modular OrchardCore CMS application with following themes. - TheAdmin Theme - SafeMode Theme - TheAgency Theme - TheBlog Theme - TheComingSoon Theme - TheTheme theme

Tabula

Extract tables from PDF files (port of tabula-java using PdfPig).

FileCurator

FileCurator is a simple manager for your files. It tries to give them a common interface to deal with files whether on your system or other locations.

GitHub repositories (16)

Showing the top 5 popular GitHub repositories that depend on PdfPig:

Repository Stars
microsoft/semantic-kernel
Integrate cutting-edge LLM technology quickly and easily into your apps
OrchardCMS/OrchardCore
Orchard Core is an open-source modular and multi-tenant application framework built with ASP.NET Core, and a content management system (CMS) built on top of that framework.
dotnet/docfx
Static site generator for .NET API documentation.
SciSharp/BotSharp
AI Multi-Agent Framework in .NET
microsoft/kernel-memory
RAG architecture: index and query any data using LLM and natural language, track sources, show citations, asynchronous memory patterns.
Version Downloads Last updated
0.1.10-alpha-20250106-f86cc 357 9 days ago
0.1.10-alpha-20250105-d1779 107 10 days ago
0.1.10-alpha-20250101-2b14a 233 14 days ago
0.1.10-alpha-20241229-50dca 263 17 days ago
0.1.10-alpha-20241216-7ec4e 902 a month ago
0.1.10-alpha-20241215-7ec4e 133 a month ago
0.1.10-alpha-20241121-7db34 3,710 2 months ago
0.1.10-alpha-20241114-8ca53 1,987 2 months ago
0.1.10-alpha-20241103-132ad 860 2 months ago
0.1.10-alpha-20241031-d3bf6 209 2 months ago
0.1.10-alpha-20241026-40af4 1,704 3 months ago
0.1.10-alpha-20241019-e1060 1,017 3 months ago
0.1.10-alpha-20241018-ea95a 156 3 months ago
0.1.10-alpha-20241016-e903b 290 3 months ago
0.1.10-alpha-20241013-f4054 241 3 months ago
0.1.10-alpha-20241008-a2580 943 3 months ago
0.1.10-alpha-20241007-c4672 498 3 months ago
0.1.9 414,966 3 months ago
0.1.9-alpha-20240930-eb9a1 4,515 4 months ago
0.1.9-alpha-20240910-4845f 69,970 4 months ago
0.1.9-alpha-20240909-09bdd 1,086 4 months ago
0.1.9-alpha-20240904-cd2a8 1,452 4 months ago
0.1.9-alpha-20240903-f4d14 736 4 months ago
0.1.9-alpha-20240902-cf45d 610 4 months ago
0.1.9-alpha-20240901-b824f 147 4 months ago
0.1.9-alpha-20240821-b4649 5,584 5 months ago
0.1.9-alpha-20240721-a99c0 27,692 6 months ago
0.1.9-alpha-20240702-65c64 10,119 6 months ago
0.1.9-alpha-20240628-bac00 9,648 7 months ago
0.1.9-alpha-20240626-14e70 957 7 months ago
0.1.9-alpha-20240625-dc933 670 7 months ago
0.1.9-alpha-20240612-d2cae 4,433 7 months ago
0.1.9-alpha-20240609-affc1 1,055 7 months ago
0.1.9-alpha-20240601-65a18 2,502 7 months ago
0.1.9-alpha-20240530-d7e43 772 8 months ago
0.1.9-alpha-20240510-d86c2 10,689 8 months ago
0.1.9-alpha-20240509-5a8e6 201 8 months ago
0.1.9-alpha-20240508-995f2 283 8 months ago
0.1.9-alpha-20240507-93779 269 8 months ago
0.1.9-alpha-20240506-b6e03 202 8 months ago
0.1.9-alpha-20240504-da44e 169 8 months ago
0.1.9-alpha-20240429-7f42a 4,100 9 months ago
0.1.9-alpha-20240419-1ef2e 7,510 9 months ago
0.1.9-alpha-20240413-0f707 11,752 9 months ago
0.1.9-alpha-20240406-2d6cb 3,621 9 months ago
0.1.9-alpha-20240402-f6292 7,577 9 months ago
0.1.9-alpha-20240324-e7896 4,892 10 months ago
0.1.9-alpha-20240318-69e2b 12,088 10 months ago
0.1.9-alpha-20240312-845e3 3,132 3/12/2024
0.1.9-alpha-20240307-ac027 1,828 3/7/2024
0.1.9-alpha-20240219-c2536 36,503 2/19/2024
0.1.9-alpha-20240217-f4e75 445 2/17/2024
0.1.9-alpha-20240216-f78b1 356 2/16/2024
0.1.9-alpha-20240215-3bdc9 1,989 2/15/2024
0.1.9-alpha-20240208-19734 4,622 2/8/2024
0.1.9-alpha-20240207-23445 1,385 2/7/2024
0.1.9-alpha-20240128-f886e 7,446 1/28/2024
0.1.9-alpha-20240121-04fc8 10,957 1/21/2024
0.1.9-alpha-20240117-096eb 5,862 1/17/2024
0.1.9-alpha-20240116-4e63e 851 1/16/2024
0.1.9-alpha-20240115-0da7b 884 1/15/2024
0.1.9-alpha-20240114-5953c 463 1/14/2024
0.1.9-alpha-20240112-83519 1,678 1/12/2024
0.1.9-alpha-20240111-88a14 847 1/11/2024
0.1.9-alpha-20240109-8cfaa 10,355 1/9/2024
0.1.9-alpha-20240108-18144 619 1/8/2024
0.1.9-alpha-20231119-4537e 17,562 11/19/2023
0.1.9-alpha-20231113-1bc0e 9,871 11/13/2023
0.1.9-alpha-20231029-17d50 5,567 10/29/2023
0.1.9-alpha-20231026-63096 5,996 10/26/2023
0.1.9-alpha-20231023-ba865 2,005 10/23/2023
0.1.9-alpha-20231019-c6e2d 4,451 10/19/2023
0.1.9-alpha-20230930-06ac8 7,528 9/30/2023
0.1.9-alpha-20230914-d59d2 7,368 9/14/2023
0.1.9-alpha-20230827-ee756 12,087 8/27/2023
0.1.9-alpha-20230806-4a480 9,080 8/6/2023
0.1.8 3,078,280 6/5/2023
0.1.8-alpha-20230605-7fe5f 1,008 6/5/2023
0.1.8-alpha-20230529-6daa2 6,663 5/29/2023
0.1.8-alpha-20230528-5126d 951 5/28/2023
0.1.8-alpha-20230524-20d3c 4,500 5/24/2023
0.1.8-alpha-20230523-11df5 963 5/23/2023
0.1.8-alpha-20230522-c3dd6 1,380 5/22/2023
0.1.8-alpha-20230423-3898f 38,446 4/23/2023
0.1.8-alpha-20230420-147b8 1,157 4/20/2023
0.1.8-alpha-20230419-2d72d 1,279 4/19/2023
0.1.8-alpha-20230417-cdc3d 1,368 4/17/2023
0.1.8-alpha-20230415-9eb79 1,093 4/15/2023
0.1.8-alpha-20230414-42e41 992 4/14/2023
0.1.8-alpha-20230413-46a04 1,085 4/13/2023
0.1.8-alpha-20230412-db058 1,728 4/12/2023
0.1.8-alpha-20230411-0e39b 1,112 4/11/2023
0.1.8-alpha-20230403-2e062 10,851 4/3/2023
0.1.8-alpha-20230331-bd4ee 18,836 3/31/2023
0.1.8-alpha-20230327-2daba 7,354 3/27/2023
0.1.8-alpha-20230326-58b33 1,117 3/26/2023
0.1.8-alpha-20230324-a3a9d 1,347 3/24/2023
0.1.8-alpha-20230323-a4861 1,137 3/23/2023
0.1.8-alpha-20230320-c024e 1,513 3/20/2023
0.1.8-alpha-20230318-a5c91 1,089 3/18/2023
0.1.8-alpha-20230219-999f9 2,788 2/19/2023
0.1.8-alpha-20230117-88aad 5,496 1/17/2023
0.1.8-alpha-20230109-65bc7 1,525 1/9/2023
0.1.7 811,318 12/13/2022
0.1.7-alpha-20221212-c8874 72,467 12/12/2022
0.1.7-alpha-20221210-2aed9 1,050 12/10/2022
0.1.7-alpha-20220814-2f9a9 6,509 8/14/2022
0.1.7-alpha-20220703-545d1 3,450 7/3/2022
0.1.7-alpha-20220622-fc71a 1,209 6/22/2022
0.1.7-alpha-20220618-f2188 1,070 6/18/2022
0.1.7-alpha-20220525-559f3 4,908 5/25/2022
0.1.7-alpha-20220511-ddab5 2,350 5/11/2022
0.1.7-alpha-20220503-4e490 1,900 5/3/2022
0.1.7-alpha-20220426-03692 1,200 4/26/2022
0.1.6 1,201,491 4/25/2022
0.1.6-alpha-20220425-2576c 1,138 4/25/2022
0.1.6-alpha-20220423-801a3 1,100 4/23/2022
0.1.6-alpha-20220415-cbd02 1,738 4/15/2022
0.1.6-alpha-20220411-09a62 1,229 4/11/2022
0.1.6-alpha-20220405-c2ecb 1,787 4/5/2022
0.1.6-alpha-20220404-6b085 1,091 4/4/2022
0.1.6-alpha-20220315-9c83e 4,466 3/15/2022
0.1.6-alpha-20220220-b0a5f 3,566 2/20/2022
0.1.6-alpha-20220116-e54cd 2,312 1/16/2022
0.1.6-alpha-20220113-5b66e 1,062 1/13/2022
0.1.6-alpha-20220112-b89c8 1,115 1/12/2022
0.1.6-alpha-20220111-41bfa 1,977 1/11/2022
0.1.5 997,149 9/17/2021
0.1.5-alpha002 5,345 5/9/2021
0.1.5-alpha001 26,233 2/28/2021
0.1.5-alpha-20211231-a57e5 2,749 12/31/2021
0.1.5-alpha-20211026-55244 1,126 10/26/2021
0.1.5-alpha-20210929-615e8 1,163 9/29/2021
0.1.5-alpha-20210918-4c36f 1,139 9/18/2021
0.1.5-alpha-20210828-e8f91 1,137 8/28/2021
0.1.5-alpha-20210827-e8f91 1,162 8/27/2021
0.1.5-alpha-20210817-b1f88 1,160 8/17/2021
0.1.4 636,251 11/29/2020
0.1.3 51,964 11/15/2020
0.1.3-alpha001 2,816 9/4/2020
0.1.2 252,516 7/4/2020
0.1.2-alpha003 1,348 6/20/2020
0.1.2-alpha002 3,618 5/10/2020
0.1.2-alpha001 1,387 4/25/2020
0.1.1 135,618 3/18/2020
0.1.1-alpha001 1,380 3/15/2020
0.1.0 203,175 1/13/2020
0.1.0-beta002 1,268 1/8/2020
0.1.0-beta001 1,267 1/6/2020
0.0.11 2,150 12/17/2019
0.0.10 1,835 12/9/2019
0.0.9 109,418 8/13/2019
0.0.7 1,744 8/3/2019
0.0.6 2,772 5/19/2019
0.0.5 19,363 12/30/2018
0.0.3 1,580 11/27/2018
0.0.1 11,251 2/26/2018
0.0.1-alpha-002 1,594 1/21/2018
0.0.1-alpha-001 1,585 1/10/2018