Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jeanslack/FFcuesplitter
FFmpeg based audio splitter for CDDA images associated with .cue files
https://github.com/jeanslack/FFcuesplitter
Last synced: 3 months ago
JSON representation
FFmpeg based audio splitter for CDDA images associated with .cue files
- Host: GitHub
- URL: https://github.com/jeanslack/FFcuesplitter
- Owner: jeanslack
- License: gpl-3.0
- Created: 2022-01-16T12:49:42.000Z (almost 3 years ago)
- Default Branch: main
- Last Pushed: 2024-01-11T14:15:24.000Z (10 months ago)
- Last Synced: 2024-05-23T04:37:48.576Z (6 months ago)
- Language: Python
- Homepage:
- Size: 288 KB
- Stars: 36
- Watchers: 1
- Forks: 5
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG
- License: LICENSE
- Authors: AUTHORS
Awesome Lists containing this project
README
# FFcuesplitter - FFmpeg-based audio splitter for CDDA images associated with .cue files .
[![Image](https://img.shields.io/static/v1?label=python&logo=python&message=3.7%20|%203.8%20|%203.9%20|%203.10%20|%203.11&color=blue)](https://www.python.org/downloads/)
[![Python application](https://github.com/jeanslack/FFcuesplitter/actions/workflows/CI.yml/badge.svg)](https://github.com/jeanslack/FFcuesplitter/actions/workflows/CI.yml)FFcuesplitter is a multi-platform CUE sheet splitter entirely based on FFmpeg.
Splits big audio tracks and automatically embeds tags using the information
contained in the associated **"CUE"** sheet. It supports multiple CUE sheet
encodings and many input formats (due to FFmpeg), including APE format, without
need installing extra audio libs and packages. It has the ability to accept both
files and directories as input while also working in recursive mode. It can be
used either as a [Python module](https://github.com/jeanslack/FFcuesplitter#using-python)
or from the [command line](https://github.com/jeanslack/FFcuesplitter#using-command-line).## Features
- Supports many input formats, due to FFmpeg.
- Convert to Wav, Flac, Ogg, Opus, and Mp3 formats.
- Ability to copy source codec and format without re-encoding.
- Batch mode processing is also available.
- Accepts both files and directories.
- Ability to perform recursive searches.
- Ability to generate audio collection directories (Artist/Album/TrackNumber - Title)
- Auto-tag from CUE file data.
- Features automatic character set detection for CUE files (via [chardet](https://pypi.org/project/chardet/)).
- Works on Linux, MacOs, FreeBSD, Windows.
- It can be used either as a Python module or from the command line.## Requires
- Python >=3.7
- [deflacue](https://pypi.org/project/deflacue/)
- [chardet](https://pypi.org/project/chardet/)
- [tqdm](https://pypi.org/project/tqdm/#description)
- [FFmpeg](https://ffmpeg.org/) *(including ffprobe)*## Using Command Line
```
ffcuesplitter -i FILENAMES DIRNAMES [FILENAMES DIRNAMES ...]
[-r]
[-f {wav,flac,mp3,ogg,opus,copy}]
[-o OUTPUTDIR]
[-c {artist+album,artist,album}]
[-ow {ask,never,always}]
[--ffmpeg-cmd URL]
[--ffmpeg-loglevel {error,warning,info,verbose,debug}]
[--ffmpeg-add-params 'parameters']
[-p {tqdm,standard}]
[--ffprobe-cmd URL]
[--dry]
[--prg-loglevel {error,warning,info,debug}]
[-h]
[--version]
```**Examples**
`ffcuesplitter -i 'inputfile_1.cue' 'inputfile_2.cue' 'inputfile_3.cue'`
Batch file processing to split and convert to default audio `flac` format.
`ffcuesplitter -i '/User/music/collection/inputfile.cue' -f ogg -o 'my_awesome_tracklist'`
To splits the individual audio tracks into `ogg` format
and saves them in the `my_awesome_tracklist` directory.**For further information and other examples visit the [wiki page](https://github.com/jeanslack/FFcuesplitter/wiki)**
***## Using Python
```python
>>> from ffcuesplitter.cuesplitter import FFCueSplitter
>>> getdata = FFCueSplitter(**kwargs)
>>> tracks = getdata.audiotracks # get all tracks data
>>> getdata.commandargs(tracks) # get FFmpeg command/arguments recipes.
```
#### Getting additionals data```python
>>> getdata.probedata # ffprobe data of the sources audio files.
>>> getdata.cue.meta.data # get CD info.
```**For further information and other examples visit the [wiki page](https://github.com/jeanslack/FFcuesplitter/wiki)**
***## Installation
`python3 -m pip install ffcuesplitter`
## License and Copyright
Copyright: (C) 2024 Gianluca Pernigotto
Author and Developer: Gianluca Pernigotto
Mail:
License: GPL3 (see LICENSE file in the source directory)