Agent Skill
2/7/2026

pdf-large-reader

pdf-large-reader Skill

V
vamseeachanta
3GitHub Stars
1Views
npx skills add vamseeachanta/workspace-hub

SKILL.md

Namepdf-large-reader
Descriptionpdf-large-reader Skill

name: pdf-large-reader version: "1.0.0" category: data description: "pdf-large-reader Skill" capabilities: [] requires: [] see_also: []

pdf-large-reader Skill

Memory-efficient PDF processing library for large files (100MB+, 1000+ pages).

Repository

Installation

cd /mnt/github/workspace-hub/pdf-large-reader
pip install -e .

Quick Usage

Python API

from pdf_large_reader import process_large_pdf, extract_text_only

# Simple text extraction
text = extract_text_only("large_document.pdf")

# Full processing with options
result = process_large_pdf(
    "document.pdf",
    output_format="generator",  # "generator", "list", or "text"
    extract_images=True,
    extract_tables=True
)

# Stream pages for memory efficiency
for page in result:
    print(f"Page {page['page_num']}: {page['text'][:100]}...")

CLI Tool

# Extract text
pdf-large-reader extract document.pdf

# Extract with options
pdf-large-reader extract document.pdf --output-format text --extract-images

# Get PDF info
pdf-large-reader info document.pdf

Key Features

FeatureDescription
StreamingGenerator output for memory efficiency
Auto StrategyIntelligent chunk sizing based on file size
Multi-formatText, images, tables, metadata extraction
ProgressBuilt-in progress callbacks
AI FallbackClaude integration for complex extraction

Output Formats

Generator (Streaming) - Default

for page in process_large_pdf("doc.pdf", output_format="generator"):
    # Process one page at a time - memory efficient
    handle_page(page)

List

pages = process_large_pdf("doc.pdf", output_format="list")
# All pages in memory - use for smaller files

Text

text = process_large_pdf("doc.pdf", output_format="text")
# Plain text concatenation

When to Use

  • Processing PDFs > 50MB
  • Batch processing many PDFs
  • Extracting content from 100+ page documents
  • Memory-constrained environments
  • Streaming PDF content to other systems

Integration Example

from pdf_large_reader import process_large_pdf
from pathlib import Path

def process_pdf_directory(directory: str):
    """Process all PDFs in a directory efficiently."""
    pdf_dir = Path(directory)

    for pdf_file in pdf_dir.glob("*.pdf"):
        print(f"Processing: {pdf_file.name}")

        # Stream pages to avoid memory issues
        for page in process_large_pdf(str(pdf_file)):
            # Index, analyze, or store each page
            yield {
                "file": pdf_file.name,
                "page": page["page_num"],
                "text": page["text"],
                "images": len(page.get("images", []))
            }

Error Handling

from pdf_large_reader import process_large_pdf
from pdf_large_reader.exceptions import PDFProcessingError

try:
    result = process_large_pdf("document.pdf")
except PDFProcessingError as e:
    print(f"PDF processing failed: {e}")
except FileNotFoundError:
    print("PDF file not found")

Related Skills

  • file-org-standards - Where to store extracted content
  • logging-standards - Logging PDF processing operations
Skills Info
Original Name:pdf-large-readerAuthor:vamseeachanta