Metadata-Version: 2.4
Name: file_conversor
Version: 0.7.4
Summary: Universal file conversor for multimedia files (audio, video, pdf, docs, etc)
Author-email: Andre Luiz Romano Madureira <andre@domain.com>
Project-URL: Homepage, https://github.com/andre-romano/file_conversor
Keywords: file,conversion,multimedia,docs,video,audio,image,converter
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.13
Classifier: Operating System :: OS Independent
Requires-Python: <=3.13.7,>=3.12
Description-Content-Type: text/markdown
License-File: LICENSE
License-File: AUTHORS.md
License-File: README.md
Requires-Dist: typer>=0.16.0
Requires-Dist: rich>=14.0.0
Requires-Dist: Babel>=2.17.0
Requires-Dist: pypdf>=5.8.0
Requires-Dist: cryptography>=45.0.5
Requires-Dist: pillow>=11.3.0
Requires-Dist: img2pdf>=0.6.1
Requires-Dist: pywin32>=311; sys_platform == "win32"
Requires-Dist: pymupdf>=1.26.3
Requires-Dist: pyyaml>=6.0.2
Requires-Dist: xmltodict>=0.14.2
Requires-Dist: toml>=0.10.2
Requires-Dist: concurrent-log-handler>=0.9.28
Requires-Dist: portalocker>=3.2.0
Requires-Dist: ocrmypdf>=16.11.0
Requires-Dist: requests>=2.32.5
Requires-Dist: flask>=3.1.2
Requires-Dist: dominate>=2.9.1
Requires-Dist: pywebview>=6.1
Requires-Dist: pycountry>=24.6.1
Requires-Dist: platformdirs>=4.5.0
Requires-Dist: natsort>=8.4.0
Requires-Dist: pdf2docx>=0.5.8
Requires-Dist: requests-cache>=1.2.1
Dynamic: license-file

<!-- [![Patreon](https://img.shields.io/badge/Patreon-Support-orange?logo=patreon)](https://www.patreon.com/andre-romano) -->

[![PyPI](https://img.shields.io/pypi/v/file_conversor.svg)](https://pypi.org/project/file_conversor/)
[![Downloads](https://static.pepy.tech/badge/file-conversor)](https://pepy.tech/project/file-conversor)
[![License](https://img.shields.io/badge/License-Apache%202.0-blue.svg)](https://opensource.org/licenses/Apache-2.0)
[![Quality Gate Status](https://sonarcloud.io/api/project_badges/measure?project=andre-romano_file_conversor&metric=alert_status)](https://sonarcloud.io/summary/new_code?id=andre-romano_file_conversor)
[![Maintainability Rating](https://sonarcloud.io/api/project_badges/measure?project=andre-romano_file_conversor&metric=sqale_rating)](https://sonarcloud.io/summary/new_code?id=andre-romano_file_conversor)
[![Reliability Rating](https://sonarcloud.io/api/project_badges/measure?project=andre-romano_file_conversor&metric=reliability_rating)](https://sonarcloud.io/summary/new_code?id=andre-romano_file_conversor)
[![Security Rating](https://sonarcloud.io/api/project_badges/measure?project=andre-romano_file_conversor&metric=security_rating)](https://sonarcloud.io/summary/new_code?id=andre-romano_file_conversor)
[![Lines of Code](https://sonarcloud.io/api/project_badges/measure?project=andre-romano_file_conversor&metric=ncloc)](https://sonarcloud.io/summary/new_code?id=andre-romano_file_conversor)


# File Conversor
A powerful Python-based CLI tool for converting, compressing, and manipulating audio, video, text, document, and image files.

**Summary**:
- [File Conversor](#file-conversor)
  - [Usage](#usage)
    - [CLI - Command line interface](#cli---command-line-interface)
    - [GUI - Graphical user interface](#gui---graphical-user-interface)
    - [Windows Context Menu (Windows OS only)](#windows-context-menu-windows-os-only)
  - [Why use File Conversor?](#why-use-file-conversor)
  - [Features](#features)
  - [External dependencies](#external-dependencies)
  - [Installing](#installing)
    - [For Windows](#for-windows)
    - [For Linux / MacOS](#for-linux--macos)
  - [Contributing \& Support](#contributing--support)
  - [License and Copyright](#license-and-copyright)

## Usage

### CLI - Command line interface

<img src="./assets/cli_demo.gif" >

Run ``file_conversor -h`` to explore all available commands and options.

### GUI - Graphical user interface

<img src="./assets/gui.jpg" >

Run ``file_conversor gui start`` to launch the GUI application or double click the Windows Shortcut.

### Windows Context Menu (Windows OS only)

1. Right click a file in Windows Explorer
2. Choose an action from "File Conversor" menu
  
<img src="./assets/ctx_menu.jpg" width="600px">

## Why use File Conversor?

- Automate repetitive file conversion or compression tasks
- Manipulate various media formats with a single tool
- Integrate seamlessly with scripting workflows
- Configure advanced file processing pipelines

## Features

- **Format Conversion**
  - **Documents**: `docx ⇄ odt`, `docx → pdf`, etc
  - **Spreadsheets**: `xlsx ⇄ ods`, `xlsx → pdf`, etc
  - **Video**: `mkv ⇄ mp4`, `avi ⇄ mp4`, etc.
  - **Images**: `jpg ⇄ png`, `gif ⇄ webp`, `bmp ⇄ tiff`, etc.
  - **Audio**: `mp3 ⇄ m4a`, etc.
  - **Text**: `json ⇄ yaml`, `xml ⇄ json`, etc
  - And more ...

- **Compression**  
  - Optimizes size for formats like MP4, MP3, PDF, JPG, and others.

- **Metadata Inspection**  
  - Retrieves EXIF data from images, stream details from audio/video.

- **File Manipulation**  
  - **PDFs**: split, rotate, encrypt, etc  
  - **Images**: rotate, enhance, and apply other transformations  

- **Batch Processing**  
  - Use pipelines and config files for automation and advanced tasks.

- **Multiple Interfaces**  
  - **Windows Explorer integration**: right-click files for quick actions
  - CLI for scripting and automation  

*For full feature set, check* [`FEATURE_SET.md`](FEATURE_SET.md)

## External dependencies

This project has external dependencies. 

In ``Windows`` and ``MacOS`` prompts will assist you in downloading missing dependencies when required. 

In `Linux` you may need to install them manually using your package manager.

## Installing

### For Windows

- **Option 1. Installer (EXE)**:
  - Download the latest version of the app (check [Releases](https://github.com/andre-romano/file_conversor/releases/) pages)
  - Execute installer (.exe file)

- **Option 2. Scoop Package Manager**
```bash
scoop install git
scoop bucket add file_conversor https://github.com/andre-romano/file_conversor
scoop install file_conversor
```

- **Option 3. Choco Package Manager**
```bash
choco install file_conversor -y
```

- **Option 4. PyPi**

```bash
pip install file_conversor
```

### For Linux / MacOS

- **Option 1. PyPi**

```bash
pip install file_conversor
```

## Contributing & Support

- **Support us**:
  - If you enjoy this project, consider supporting us with a donation in our Github Sponsors.
- **Acknowledgements**
  - We're grateful to the icon designers whose work is featured in the app: [Freepik](https://www.flaticon.com/authors/freepik), [atomicicon](https://www.flaticon.com/authors/atomicicon), [swifticons](https://www.flaticon.com/authors/swifticons), [iconir](https://www.flaticon.com/authors/iconir), [iconjam](https://www.flaticon.com/authors/iconjam), [muhammad-andy](https://www.flaticon.com/authors/muhammad-andy), [Shuvo.Das](https://www.flaticon.com/authors/shuvodas), [Laisa Islam Ani](https://www.flaticon.com/authors/laisa-islam-ani), [riajulislam](https://www.flaticon.com/authors/riajulislam), [howcolour](https://www.flaticon.com/authors/howcolour) (via [Flaticon](https://www.flaticon.com))

## License and Copyright

Distributed under the **Apache License 2.0**. See [`LICENSE`](./LICENSE) for details.

