Skip to main content

A text-extraction application that facilitates string consumption.

Project description

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

  • 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

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.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

textspitter-1.0.0.tar.gz (29.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

textspitter-1.0.0-py3-none-any.whl (21.8 kB view details)

Uploaded Python 3

File details

Details for the file textspitter-1.0.0.tar.gz.

File metadata

  • Download URL: textspitter-1.0.0.tar.gz
  • Upload date:
  • Size: 29.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.25

File hashes

Hashes for textspitter-1.0.0.tar.gz
Algorithm Hash digest
SHA256 7d6702839cf2ba62b24480795f2b26fe5f92986b4a230991d5c8034534607632
MD5 cb92f1a72f0d74204c246468ce0bb07d
BLAKE2b-256 55099506e7cea71d1aa591b1ab898fdf522f1dd2c01ac37f4fed451c19cfd187

See more details on using hashes here.

File details

Details for the file textspitter-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: textspitter-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 21.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.25

File hashes

Hashes for textspitter-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 7d5ab80d59f6bf2253b302693594cbf1f44158cd9b4427d542ba7370d445cad4
MD5 73473ad936473580a42b0098c8f49c91
BLAKE2b-256 13391099bed4c75f6fc2e0952f701c081f3b9eeb11a135dad1fbcf532bcac335

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page