Metadata-Version: 2.4
Name: ffmpegp
Version: 1.30
Summary: ffmpegp is an enhanced version of FFmpeg, offering additional features and functionalities to extend its powerful media processing capabilities.
Author: Ankush Bhagat
Author-email: <ankushbhagatofficial@gmail.com>
Keywords: python,ffmpeg,ffmpegp,automation,converter,encoding,progressbar
Classifier: Intended Audience :: Developers
Classifier: Programming Language :: Python :: 3
Classifier: Operating System :: Unix
Classifier: Operating System :: MacOS :: MacOS X
Classifier: Operating System :: Microsoft :: Windows
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: jsonpath_ng
Requires-Dist: pyargument
Dynamic: author
Dynamic: author-email
Dynamic: classifier
Dynamic: description
Dynamic: description-content-type
Dynamic: keywords
Dynamic: license-file
Dynamic: requires-dist
Dynamic: summary


<div align="center">
<kbd>
  <img src="https://github.com/user-attachments/assets/76839d9d-c21d-447b-82ac-9823d0653162" alt="ffmpegp-logo" />
</kbd>
</div><br>

ffmpegp (short for "FFmpeg Plus") is a Python-based utility designed to simplify working with media files using ffprobe and ffmpeg. This tool lets you easily extract media details, format conversions, and advanced querying via JSON paths, providing a convenient and efficient interface.

## Preview
<div align="center">
<kbd>
  <img src="https://github.com/user-attachments/assets/bab2f5a5-9b61-46ce-a708-029174d6f8b7" /> 
</kbd>
</div><br>

<div align="center">
<kbd>
  <img src="https://github.com/user-attachments/assets/508753ab-b30e-4b67-b0b6-ec115408674e" /> 
</kbd>
</div><br>


<div align="center">
<kbd>
  <img src="https://github.com/user-attachments/assets/101c7838-5e7e-4b29-8f6e-7c7c8df9e167" /> 
</kbd>
</div><br>

## Features

* **Media Metadata Extraction** : Get detailed media information via `ffprobe`.
* **JSONPath Querying** : Retrieve specific metadata using JSON path expressions.
* **Gradient Text** : Colored gradient output for enhanced readability.
* **Progress Bar** : Visual progress bar with customizable colors and time estimation.
* **File Size Conversion** : Converts file size to human-readable formats.
* **Time Conversion** : Converts media duration to seconds.
* **Enhanced Command Options** : Supports various flags for different modes and output styles.

## Prerequisites

Ensure `ffmpeg` and `ffprobe` are installed and accessible in your system's PATH. If either is missing, the script will display an error.

## Installation

Install **ffmpegp** using `pip`:

```
pip install ffmpegp
```

## Usage

Run the program as follows:

```
ffmpegp -i <file_path> [options]
```

### Arguments

* `file_path`: Path to the media file for which you want details.

### Options

| Option        | Description                                             |
| ------------- | ------------------------------------------------------- |
| `--colored` | Enable gradient color output.                           |
| `--log`     | Display logs of the running process.                    |
| `--stdout`  | Print only plain text without any colored output.       |
| `--jq`      | Query specific JSON data (e.g.,`format.filename`).    |
| `--dir`     | Enable multi-file processing mode in a directory.       |
| `--format`  | Set specific file format to find. (works with '--dir' tag) (default: all) (e.g., --format=mp4). |

## Example Commands

Get media details:

```
ffmpegp "video.mp4"
```

Get specific JSON data:

```
ffmpegp "video.mp4" --jq="format.filename"
```

Enable gradient color progress output:

```
ffmpegp -i "video.mp4" [options] --colored
```

Run in directory mode and select only (mp4) extension files and save files to "output" folder with same filename with diffrent file extension (mkv).:

```
ffmpegp -i "{}" <options> "/output/{}.mkv" --dir="./videos" --format="mp4"
```

## Contributing

Contributions are welcome! If you have any suggestions, bug reports, or feature requests, please open an issue or submit a pull request on GitHub.

## License

This project is licensed under the GNU LESSER GENERAL PUBLIC LICENSE - see the [LICENSE](https://github.com/ankushbhagats/ffmpegp/blob/master/LICENSE) file for details.
