/PDF-Search-Plus

A Python application that extracts text and images from PDFs, applies OCR to images using Tesseract, and stores the results in a SQLite database. The application features a GUI for searching both text and OCR-extracted content and previewing PDF files.

Primary LanguagePythonMIT LicenseMIT

PDF Search and OCR Application

This Python application processes PDF files by extracting text from the pages and images, applying OCR (Optical Character Recognition) to images, and storing the results in a SQLite database. It provides a graphical user interface (GUI) built with Tkinter to search and preview the PDF content, including OCR-extracted text.

Features

  • Extracts and stores text from PDF pages.
  • Extracts images from PDF pages and applies OCR using Tesseract or EasyOCR.
  • Stores image metadata and OCR-extracted text into the SQLite database.
  • Provides a user-friendly GUI for searching through the stored data, including PDF text and OCR text.
  • Allows for both single-file and folder-based (batch) PDF processing.
  • Enables preview of PDFs with zoom and navigation features.

Prerequisites

Before running the application, you need to install the following dependencies. You have two options depending on whether you're using Tesseract or EasyOCR for OCR functionality.

Installation Instructions

  1. Install the required Python packages using pip based on your chosen OCR engine.

    • For Tesseract users:

      pip install -r requirements.txt

      This will install the following packages:

      • PyMuPDF
      • Pillow
      • pytesseract
      • threaded
    • For EasyOCR users:

      pip install -r requirements.txt

      This will install the following packages:

      • PyMuPDF
      • Pillow
      • easyocr
      • numpy
      • threaded
  2. Tesseract OCR Installation (if using Tesseract):

    • On Ubuntu:
      sudo apt install tesseract-ocr
    • On MacOS (using Homebrew):
      brew install tesseract
    • On Windows: Download and install from Tesseract OCR for Windows.
  3. Ensure that tesseract is in your system’s PATH if using Tesseract.

Using pdf_processor_easyocr.py

For users who cannot install Tesseract on Windows or prefer a simpler setup, we provide the alternative pdf_processor_easyocr.py script, which uses EasyOCR for OCR extraction instead of Tesseract.

  • To run the version of the app using EasyOCR, simply execute:

    python pdf_processor_easyocr.py

This will provide the same functionality without requiring the user to install Tesseract.

Database Schema

The application stores PDF data in an SQLite database called pdf_data.db. The following tables are used to store the extracted data:

  • pdf_files: Stores metadata for each processed PDF file.

    CREATE TABLE pdf_files (
        id INTEGER PRIMARY KEY AUTOINCREMENT,
        file_name TEXT,
        file_path TEXT
    );
  • pages: Stores text extracted from each PDF page.

    CREATE TABLE pages (
        id INTEGER PRIMARY KEY AUTOINCREMENT,
        pdf_id INTEGER,
        page_number INTEGER,
        text TEXT,
        FOREIGN KEY(pdf_id) REFERENCES pdf_files(id)
    );
  • images: Stores metadata about extracted images from the PDF.

    CREATE TABLE images (
        id INTEGER PRIMARY KEY AUTOINCREMENT,
        pdf_id INTEGER,
        page_number INTEGER,
        image_name TEXT,
        image_ext TEXT,
        FOREIGN KEY(pdf_id) REFERENCES pdf_files(id)
    );
  • ocr_text: Stores the text extracted via OCR from images.

    CREATE TABLE ocr_text (
        id INTEGER PRIMARY KEY AUTOINCREMENT,
        pdf_id INTEGER,
        page_number INTEGER,
        ocr_text TEXT,
        FOREIGN KEY(pdf_id) REFERENCES pdf_files(id)
    );

Usage

  1. Running the Application:

    • To start the Tesseract-based version of the application, run the main() function in the pdf_search_gui.py script:

      python pdf_search_gui.py
    • To start the EasyOCR-based version of the application, run the main() function in pdf_processor_easyocr.py:

      python pdf_processor_easyocr.py
  2. Processing PDF Files:

    • The application provides two options:
      • Single File: Select a single PDF file to process.
      • Batch Processing: Select a folder containing multiple PDFs for processing.

    After processing, the text, images, and OCR data will be stored in the SQLite database.

  3. Searching for Text:

    In the GUI, enter a search term and press "Search". The application will search both PDF page text and OCR-extracted text from images. The results will be displayed in a table, showing the PDF file name, page number, and matching context.

  4. Previewing PDF Pages:

    From the search results, you can select a PDF and page to preview. The selected PDF page will be displayed in the right-hand pane of the GUI, with zoom and navigation controls available.

Code Structure

  • PDF Processing:

    • The Tesseract-based version (pdf_search_gui.py) uses pytesseract to perform OCR on extracted images from PDFs.
    • The EasyOCR-based version (pdf_processor_easyocr.py) uses EasyOCR to perform OCR on extracted images from PDFs. Images extracted from the PDF are converted to NumPy arrays before being passed to EasyOCR for processing.
  • Database Interaction: The script inserts extracted PDF text, image metadata, and OCR results into the SQLite database. It provides search functionality for both PDF text and OCR-extracted text.

How It Works

  1. Text Extraction: For each page in the PDF, text is extracted using PyMuPDF and inserted into the pages table in the database.

  2. Image Extraction and OCR:

    • Tesseract version: For each image found in the PDF, metadata is saved in the images table. The image is passed to Tesseract to extract text via OCR, and the result is stored in the ocr_text table.
    • EasyOCR version: In the EasyOCR version (pdf_processor_easyocr.py), each image is extracted from the PDF, converted into a NumPy array, and passed to EasyOCR for text extraction. The extracted text is stored in the ocr_text table.

    Note: EasyOCR requires image input in specific formats, including file paths, URLs, bytes, or NumPy arrays. The application automatically handles the conversion to a NumPy array before passing the image to EasyOCR.

  3. Search: The user can search both the pages table (PDF text) and the ocr_text table (OCR text from images). The results are combined and displayed in the GUI.

  4. Preview: The selected PDF file is opened and rendered in the GUI's canvas area, allowing the user to view the selected page.

Example Usage

  1. Single PDF File:

    • Open the application.
    • Choose a PDF file to process.
    • Search for text or OCR data using the search bar.
    • View the search results and select a page to preview.
  2. Batch Processing:

    • Select a folder containing multiple PDF files.
    • The application will process all PDFs and extract text, images, and OCR data.
    • Perform searches across all processed files.

Error Handling and Logging

  • All errors during processing are logged to app.log, and the user is notified of issues via GUI pop-up messages.

License

This project is open-source and available under the MIT License.


Future Enhancements

  • Add support for exporting search results.
  • Improve image OCR accuracy with advanced preprocessing.
  • Add annotations for highlighted text in preview mode.