Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[SPARKNLP-1098] Adding PDF reader support #14499

Open
wants to merge 2 commits into
base: master
Choose a base branch
from

Conversation

danilojsl
Copy link
Contributor

Description

This pull request introduces a new feature that enables reading and parsing PDF files into a structured Spark DataFrame. Leveraging this functionality allows for efficient processing and analysis of PDF content, seamlessly integrating with Spark NLP for enhanced downstream natural language processing tasks.

Key Changes

Added sparknlp.read().pdf() Method: This method accepts file paths or a file path to parse PDF content into a Spark DataFrame.
Support for Varied Sources: The method is designed to handle both local directories, and distributed file systems containing email files.

Motivation and Context

How Has This Been Tested?

Screenshots (if appropriate):

  • Structured Data Representation: By transforming raw PDF content into a well-defined DataFrame structure, we enable seamless integration with Spark’s powerful analytical and data processing capabilities.
  • Scalability: Leveraging Spark’s distributed architecture, this feature supports the efficient processing of large volumes of email data, which is critical for big data projects.
  • Simplified Data Manipulation: Working with a structured DataFrame simplifies data manipulation tasks, such as filtering, aggregating, and transforming email content, reducing complexity and improving productivity.
  • Enhanced Context for LLM Tasks: By organizing PDF data into structured formats, we can curate and provide more specific, context-rich content for large language model (LLM) prompts. This improves the quality of LLM-generated outputs by allowing for more targeted and relevant contextual information, which is essential for applications like NLU and content generation.

Types of changes

  • Bug fix (non-breaking change which fixes an issue)
  • Code improvements with no or little impact
  • New feature (non-breaking change which adds functionality)
  • Breaking change (fix or feature that would cause existing functionality to change)

Checklist:

  • My code follows the code style of this project.
  • My change requires a change to the documentation.
  • I have updated the documentation accordingly.
  • I have read the CONTRIBUTING page.
  • I have added tests to cover my changes.
  • All new and existing tests passed.

@danilojsl danilojsl added DON'T MERGE Do not merge this PR new-feature Introducing a new feature labels Jan 14, 2025
@danilojsl danilojsl force-pushed the feature/SPARKNLP-1098-Adding-a-PDF-Reader-to-Spark-NLP branch from a5e7f0b to 4cd472d Compare January 15, 2025 20:41
@danilojsl danilojsl self-assigned this Jan 16, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
DON'T MERGE Do not merge this PR new-feature Introducing a new feature
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant