Skip to main content

Python module to easily run scripts in modular frameworks Written by pedrohenriquecoimbra

Project description

FrameworkAPI, a Modular Framework Runner

Shows an illustrated sun in light mode and a moon with stars in dark mode.

A Python module for creating fully modular and extensible workflows by combining scripts in different languages, managing YAML-based configurations, and offering an API for seamless integration.


Features

🚀 Script Runner

Easily run scripts written in Python, R, or Julia with dynamic argument support.

  • Automatic Language Detection: Identify script type and invoke the appropriate runtime (e.g., python, Rscript, julia).
  • Flexible Argument Passing: Pass command-line arguments directly to scripts for parameterized execution.
  • Robust Error Handling: Logs and handles errors during script execution.

📜 YAML Configuration Handler

Effortlessly parse, validate, and manage YAML files with cross-references.

  • Dynamic Parsing: Load YAML configurations into Python objects.
  • Cross-Reference Resolution: Automatically resolve dependencies between keys within a single file or across multiple files.
  • Flexible Configuration Management: Merge or extend YAML files to build modular workflows.

🛠 High-Level API for Script Execution

A simple API to link scripts and configurations for easy execution.

  • Script Discovery: Fetch script paths and parameters from the YAML configuration.
  • Workflow Automation: Execute scripts dynamically based on configuration settings.
  • Extensibility: Add hooks for pre- and post-processing or extend functionality as needed.

Installation

pip install FrameworkAPI

Quickstart

1️⃣ Define Your Configuration (config.yaml)

scripts:
  preprocess:
    path: "scripts/preprocess.py"
    args:
      input_file: "data/raw.csv"
      output_file: "data/processed.csv"
  analyze:
    path: "scripts/analyze.R"
    args:
      input_file: "data/processed.csv"
      report_file: "results/report.html"

workflow:
  - preprocess
  - analyze

2️⃣ Run Scripts Using the API

from FrameworkAPI import FrameworkAPI

# Load configuration
framework = FrameworkAPI("config.yaml")

# Execute the entire workflow
framework.run_workflow()

# Or execute a single script by name
framework.run_script("preprocess")

3️⃣ Seamlessly Handle Multiple Languages

The module automatically detects the script type and runs the appropriate interpreter:

  • .pypython
  • .RRscript
  • .jljulia

Directory Structure

project/
├── config.yaml          # Your YAML configuration file
├── scripts/             # Directory for scripts
│   ├── preprocess.py    # Python script
│   ├── analyze.R        # R script
├── results/             # Output directory
└── main.py              # Main Python script

Advanced Features

  • Cross-References in YAML: Use references to reuse values across the configuration.

    data_dir: "data/"
    scripts:
      preprocess:
        input_file: "${data_dir}raw.csv"
        output_file: "${data_dir}processed.csv"
    
  • Custom Hooks: Add pre- or post-processing logic in Python for additional control.


Contributing

We welcome contributions! Please submit a pull request or open an issue for bug reports, feature requests, or questions.


License

This project is licensed under the MIT License.


Contact

Feel free to reach out for support or collaboration:


Happy scripting! ✨

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

frameworkapi-0.0.3.tar.gz (6.6 kB view details)

Uploaded Source

Built Distribution

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

FrameworkAPI-0.0.3-py3-none-any.whl (12.6 kB view details)

Uploaded Python 3

File details

Details for the file frameworkapi-0.0.3.tar.gz.

File metadata

  • Download URL: frameworkapi-0.0.3.tar.gz
  • Upload date:
  • Size: 6.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.8.12

File hashes

Hashes for frameworkapi-0.0.3.tar.gz
Algorithm Hash digest
SHA256 edb0c63310d2fdda34912b97648f342d555402d0285a83363515ca0c7460eb9f
MD5 50ac8e2b126a8e67092cd8a9c72df66b
BLAKE2b-256 2078cd7c620dd7ff3ae4e36ab4fc793bb0cb7cc22048730892ea8b1b314c5b54

See more details on using hashes here.

File details

Details for the file FrameworkAPI-0.0.3-py3-none-any.whl.

File metadata

  • Download URL: FrameworkAPI-0.0.3-py3-none-any.whl
  • Upload date:
  • Size: 12.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.8.12

File hashes

Hashes for FrameworkAPI-0.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 33e9d0d0f9f8d9a243b13e148b94de727f5e398b24d2f6e2f8553e0813b632f6
MD5 911af452aeb93cbd87b1f5a3cb711e50
BLAKE2b-256 bad48f5e4e7e76748d5daac41733fafd8bd39b3acfe6a2c367a4f3f0c9a6f651

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