Skip to content

fsecada01/TextSpitter

Folders and files

NameName
Last commit message
Last commit date

Latest commit

ย 

History

78 Commits
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 

Repository files navigation

TextSpitter

Transforming documents into insights, effortlessly and efficiently.

license last-commit repo-top-language repo-language-count docs

Built with the tools and technologies:

TOML Pytest Python GitHub%20Actions uv


Table of Contents


Overview

TextSpitter is a lightweight Python library that extracts text from documents and source-code files with a single call. It normalises diverse input types โ€” file paths, BytesIO streams, SpooledTemporaryFile objects, and raw bytes โ€” into plain strings, making it ideal for pipelines that feed text into LLMs, search engines, or data-processing workflows.

Why TextSpitter?

  • ๐Ÿ“„ Multi-format extraction โ€” PDF (PyMuPDF + PyPDF fallback), DOCX, TXT, CSV, and 50 + programming-language file types.
  • ๐Ÿ”Œ Stream-first API โ€” accepts file paths, BytesIO, SpooledTemporaryFile, or raw bytes; no temp files required.
  • ๐Ÿ› ๏ธ Optional structured logging โ€” install textspitter[logging] to add loguru; falls back to stdlib logging transparently.
  • ๐Ÿ–ฅ๏ธ CLI included โ€” uv tool install textspitter gives you a textspitter command for quick one-off extractions.
  • ๐Ÿš€ Automated CI/CD โ€” GitHub Actions run the test matrix (Python 3.12โ€“3.14) and publish docs to GitHub Pages on every push.

Features

Component Details
โš™๏ธ Architecture
  • Three-layer design: TextSpitter convenience function โ†’ WordLoader dispatcher โ†’ FileExtractor low-level reader
  • OOP design enables straightforward subclassing and extension
๐Ÿ”ฉ Code Quality
  • Strict PEP 8 / ruff linting with black formatting
  • Full type hints; ships a py.typed PEP 561 marker
๐Ÿ“„ Documentation
  • API docs auto-published to GitHub Pages via pdoc
  • Quick-start guide, tutorial, use-case examples, and recipes
๐Ÿ”Œ Integrations
  • CI/CD with GitHub Actions (tests + docs + PyPI publish)
  • Package management via uv; installable via pip or uv tool install
๐Ÿงฉ Modularity
  • Core FileExtractor separated from dispatch logic in WordLoader
  • Logging abstraction in logger.py isolates the optional loguru dependency
๐Ÿงช Testing
  • ~70 pytest tests covering all readers and input types
  • Dual-mode log capture fixture works with or without loguru
โšก๏ธ Performance
  • Class-level frozenset / dict constants avoid per-call allocation
  • Stream rewind avoids re-reading large files
๐Ÿ“ฆ Dependencies
  • Core: pymupdf, pypdf, python-docx
  • Optional logging: loguru (pip install textspitter[logging])

Project Structure

TextSpitter/
โ”œโ”€โ”€ .github/
โ”‚   โ””โ”€โ”€ workflows/
โ”‚       โ”œโ”€โ”€ docs.yml             # pdoc โ†’ GitHub Pages
โ”‚       โ”œโ”€โ”€ python-publish.yml   # PyPI release
โ”‚       โ””โ”€โ”€ tests.yml            # pytest matrix (3.12 โ€“ 3.14)
โ”œโ”€โ”€ TextSpitter/
โ”‚   โ”œโ”€โ”€ __init__.py              # TextSpitter() + WordLoader public API
โ”‚   โ”œโ”€โ”€ cli.py                   # argparse CLI entry point
โ”‚   โ”œโ”€โ”€ core.py                  # FileExtractor class
โ”‚   โ”œโ”€โ”€ logger.py                # Optional loguru / stdlib fallback
โ”‚   โ”œโ”€โ”€ main.py                  # WordLoader dispatcher
โ”‚   โ”œโ”€โ”€ py.typed                 # PEP 561 marker
โ”‚   โ””โ”€โ”€ guide/                   # pdoc documentation pages (subpackage)
โ”œโ”€โ”€ tests/
โ”‚   โ”œโ”€โ”€ conftest.py              # shared fixtures (log_capture)
โ”‚   โ”œโ”€โ”€ test_cli.py
โ”‚   โ”œโ”€โ”€ test_file_extractor.py
โ”‚   โ”œโ”€โ”€ test_txt.py
โ”‚   โ””โ”€โ”€ ...
โ”œโ”€โ”€ CHANGELOG.md
โ”œโ”€โ”€ CONTRIBUTING.md
โ”œโ”€โ”€ pyproject.toml
โ””โ”€โ”€ uv.lock

Getting Started

Prerequisites

  • Python โ‰ฅ 3.12
  • uv (recommended) or pip

Installation

From PyPI:

pip install textspitter

# With optional loguru logging
pip install "textspitter[logging]"

Using uv:

uv add textspitter

# With optional loguru logging
uv add "textspitter[logging]"

As a standalone CLI tool:

uv tool install textspitter

From source:

git clone https://github.com/fsecada01/TextSpitter.git
cd TextSpitter
uv sync --all-extras --dev

Usage

As a library (one-liner):

from TextSpitter import TextSpitter

# From a file path
text = TextSpitter(filename="report.pdf")
print(text)

# From a BytesIO stream
from io import BytesIO
text = TextSpitter(file_obj=BytesIO(pdf_bytes), filename="report.pdf")

# From raw bytes
text = TextSpitter(file_obj=docx_bytes, filename="contract.docx")

Using the WordLoader class directly:

from TextSpitter.main import WordLoader

loader = WordLoader(filename="data.csv")
text = loader.file_load()

As a CLI tool:

# Extract a single file to stdout
textspitter report.pdf

# Extract multiple files and write to a combined output file
textspitter file1.pdf file2.docx notes.txt -o combined.txt

Testing

uv run pytest tests/

# With coverage
uv run pytest tests/ --cov=TextSpitter --cov-report=term-missing

Roadmap

v1.x (current)

  • Stream-based API (BytesIO, SpooledTemporaryFile, raw bytes)
  • CLI entry point (uv tool install textspitter)
  • Optional loguru logging with stdlib fallback
  • Programming-language file support (50 + extensions)
  • CI matrix (Python 3.12 โ€“ 3.14) + GitHub Pages docs
  • Async extraction API
  • CSV โ†’ structured output (list of dicts)
  • PPTX support

v2.0 โ€” Rust backend (full roadmap)

  • Rust splitting core via PyO3 + Maturin โ€” 10xโ€“40x batch throughput
  • Graceful Python fallback when Rust extension is unavailable
  • manylinux wheels on PyPI โ€” zero-compile install for Linux users
  • Memory-mapped file processing for very large PDFs (memmap2)
  • SIMD-accelerated string search for separator detection
  • Streaming iterator API (yield chunks instead of collecting all)
  • Optional SIMD feature flag (pip install "textspitter[simd]")

Contributing

Contributing Guidelines
  1. Fork the Repository: Fork the project to your GitHub account.
  2. Clone Locally: Clone the forked repository.
    git clone https://github.com/fsecada01/TextSpitter.git
  3. Create a New Branch: Always work on a new branch.
    git checkout -b new-feature-x
  4. Make Your Changes: Develop and test your changes locally.
  5. Commit Your Changes: Commit with a clear message.
    git commit -m 'Add new feature x.'
  6. Push to GitHub: Push the changes to your fork.
    git push origin new-feature-x
  7. Submit a Pull Request: Create a PR against main. Describe the changes and motivation clearly.
  8. Review: Once approved, your PR will be merged. Thanks for contributing!
Contributor Graph


License

TextSpitter is released under the MIT License.

About

Python package that spits out text from your document files!

Resources

License

Contributing

Stars

Watchers

Forks

Packages

 
 
 

Contributors

Languages