Kindle Comic Converter is a Python app to convert comic/manga files or folders to EPUB, Panel View MOBI or E-Ink optimized CBZ. It was initially developed for Kindle but since version 4.6 it outputs valid EPUB 3.0 so despite its name, KCC is actually a comic/manga to EPUB converter that every e-reader owner can happily use. It can also optionally optimize images by applying a number of transformations.
KCC is not Amazon's Kindle Comic Creator nor is in any way endorsed by Amazon. Amazon's tool is for comic publishers and involves a lot of manual effort, while KCC is for comic/manga readers. KC2 in no way is a replacement for KCC so you can be quite confident we are going to carry on developing our little monster ;-)
If you have general questions about usage, feedback etc. please post it here. If you have some technical problems using KCC please file an issue here. If you can fix an open issue, fork & make a pull request.
If you find KCC valuable you can consider donating to the authors:
You can find the latest binary at the following link:
- Windows (64-bit only)
- macOS (10.14+)
- Linux: Currently unavailable.
see: KindleComicConverter_osx_*.dmg in https://github.com/ciromattia/kcc/releases
If you can't open the last beta and the OS says it's damaged, fix it with:
xattr -d com.apple.quarantine /Applications/Kindle\ Comic\ Converter.app
Building is not available in github on M1 arch.
See this building method, to build it locally:
Originally posted by @celogeek in darodi#4 (comment)
If you can't open the last beta and the OS says it's damaged, fix it with:
xattr -d com.apple.quarantine /Applications/Kindle\ Comic\ Converter.app
Or you could also have a look at this other project: https://github.com/celogeek/go-comic-converter
- make binary executable
$ chmod a+x kcc_linux
- install 7zip
$ sudo apt-get install -y p7zip-full
- Download kindlegen
$ wget -qO- https://archive.org/download/kindlegen_linux_2_6_i386_v2_9/kindlegen_linux_2.6_i386_v2_9.tar.gz | tar xvz kindlegen - copy kindlegen into '/usr/local/bin' and grant execute permissions for MOBI conversion.
$ sudo cp -R kindlegen /usr/local/bin && sudo chmod a+x /usr/local/bin/kindlegen - run with backend x11 or it might not work with fedora
$ GDK_BACKEND=x11 ./kcc_linux
KCC is also available on PyPI.
On Debian based distributions these two commands should install all needed dependencies:
$ sudo apt-get install python3 python3-dev python3-pip libpng-dev libjpeg-dev p7zip-full python3-pyqt5
$ pip3 install --user --upgrade pillow python-slugify psutil pyqt5 ravenbeta version
$ pip install --index-url https://test.pypi.org/simple/ KindleComicConverterDarodistable version
$ pip install --user KindleComicConverter- install 7zip
$ sudo apt-get install -y p7zip-full
- Download kindlegen
$ wget -qO- https://archive.org/download/kindlegen_linux_2_6_i386_v2_9/kindlegen_linux_2.6_i386_v2_9.tar.gz | tar xvz kindlegen - copy kindlegen into '/usr/local/bin' and grant execute permissions for MOBI conversion.
$ sudo cp -R kindlegen /usr/local/bin && sudo chmod a+x /usr/local/bin/kindlegen - make appImage executable
$ chmod a+x kindleComicConverter-latest-x86_64.AppImage
- run with backend x11 or it might not work with fedora
$ GDK_BACKEND=x11 ./kindleComicConverter-latest-x86_64.AppImage
install kindlegen in your working directory and get last docker image
$ wget -qO- https://archive.org/download/kindlegen_linux_2_6_i386_v2_9/kindlegen_linux_2.6_i386_v2_9.tar.gz | tar xvz kindlegen$ docker pull ghcr.io/ciromattia/kcc:latestexecute kcc-c2e
$ docker run --rm -v "$(pwd):/app" ghcr.io/ciromattia/kcc:latest example
$ docker run --rm -v "$(pwd):/app" ghcr.io/ciromattia/kcc:latest -p KPW5 ./1.cbzexecute kcc-c2p
$ docker run --entrypoint /opt/kcc/kcc-c2p.py --rm -v "$(pwd):/app" ghcr.io/ciromattia/kcc:latest Following software is required to run Linux version of KCC and/or bare sources:
- Python 3.3+
- PyQt5 5.6.0+ (only needed for GUI)
- Pillow 4.0.0+ (5.2.0+ needed for WebP support)
- psutil 5.0.0+
- python-slugify 1.2.1+, <8.0.0
- raven 6.0.0+ (only needed for GUI)
On Debian based distributions these two commands should install all needed dependencies:
$ sudo apt-get install python3 python3-dev python3-pip libpng-dev libjpeg-dev p7zip-full python3-pyqt5
$ pip3 install --user --upgrade pillow python-slugify psutil pyqt5 raven- Qt platform integration plugin for Deepin Desktop Environment
$ sudo apt-get install qt5dxcb-plugin- KindleGen
deprecated linkv2.9+ in a directory reachable by your PATH or in KCC directory *(For MOBI generation) – which offers a command line interface and supports Linux (mirror1), Mac OSX and Windows – has been deprecated, but binaries can still be found on the internet. - 7z (For CBZ/ZIP, CBR/RAR, 7z/CB7 support)
Originally posted by @hhtien1408 in ciromattia#438 (comment)
$ git clone https://github.com/ciromattia/kcc.gitOn Debian based distributions these two commands should install all needed dependencies:
$ sudo apt-get install python3 python3-dev python3-pip libpng-dev libjpeg-dev p7zip-full python3-pyqt5Then install the necessary packages. You can do it by running the following command. The requirements.txt file is inside this repository, you will see it when you clone the repo.
$ pip3 install -r 'requirements.txt' This should install the required packages. You can check the version by running
$ pip3 freezeIf the packages are in the wrong version, you can try to upgrade them by running
$ pip3 install --upgrade name_of_the_packageDownload kindlegen.
$ wget https://archive.org/download/kindlegen_linux_2_6_i386_v2_9/kindlegen_linux_2.6_i386_v2_9.tar.gz | tar xvzf kindlegenCopy kindlegen into '/usr/local/bin' and grant execute permissions for MOBI conversion.
$ sudo cp -R '/home/user/Desktop/kindlegen' '/usr/local/bin'
$ sudo chmod +rwx '/usr/local/bin/kindlegen' Run python file for KCC GUI
$ python3 kcc.pyIf everything goes well, you now should be able to use it.
Create destop file in '~/.local/share/applications' with codes:
#!/usr/bin/env xdg-open
[Desktop Entry]
Type=Application
Name=Kindle Comic Converter
Icon=kcc
Exec=python3 '/home/user/kcc/kcc.py'
Terminal=false
StartupWMClass=kcc
Name[en_US]=Kindle Comic Converter
Copy icon file into '/home/user/.local/share/icons'
$ sudo cp -R 'icons/comic2ebook.png' '/home/user/.local/share/icons'KCC can understand and convert, at the moment, the following input types:
- Folders containing: PNG, JPG, GIF or WebP files
- CBZ, ZIP (With
7zexecutable) - CBR, RAR (With
7zexecutable) - CB7, 7Z (With
7zexecutable) - PDF (Only extracting JPG images)
Should be pretty self-explanatory. All options have detailed information in tooltips. After completed conversion, you should find ready file alongside the original input file (same directory).
Please check our wiki for more details.
CLI version of KCC is intended for power users. It allows using options that might not be compatible and decrease the quality of output.
'K1': ("Kindle 1", (600, 670), Palette4, 1.8),
'K11': ("Kindle 11", (1072, 1448), Palette16, 1.8),
'K2': ("Kindle 2", (600, 670), Palette15, 1.8),
'K34': ("Kindle Keyboard/Touch", (600, 800), Palette16, 1.8),
'K578': ("Kindle", (600, 800), Palette16, 1.8),
'KDX': ("Kindle DX/DXG", (824, 1000), Palette16, 1.8),
'KPW': ("Kindle Paperwhite 1/2", (758, 1024), Palette16, 1.8),
'KV': ("Kindle Paperwhite 3/4/Voyage/Oasis", (1072, 1448), Palette16, 1.8),
'KPW5': ("Kindle Paperwhite 5/Signature Edition", (1236, 1648), Palette16, 1.8),
'KO': ("Kindle Oasis 2/3", (1264, 1680), Palette16, 1.8),
'KS': ("Kindle Scribe", (1860, 2480), Palette16, 1.8),
'KoMT': ("Kobo Mini/Touch", (600, 800), Palette16, 1.8),
'KoG': ("Kobo Glo", (768, 1024), Palette16, 1.8),
'KoGHD': ("Kobo Glo HD", (1072, 1448), Palette16, 1.8),
'KoA': ("Kobo Aura", (758, 1024), Palette16, 1.8),
'KoAHD': ("Kobo Aura HD", (1080, 1440), Palette16, 1.8),
'KoAH2O': ("Kobo Aura H2O", (1080, 1430), Palette16, 1.8),
'KoAO': ("Kobo Aura ONE", (1404, 1872), Palette16, 1.8),
'KoN': ("Kobo Nia", (758, 1024), Palette16, 1.8),
'KoC': ("Kobo Clara HD/Kobo Clara 2E", (1072, 1448), Palette16, 1.8),
'KoL': ("Kobo Libra H2O/Kobo Libra 2", (1264, 1680), Palette16, 1.8),
'KoF': ("Kobo Forma", (1440, 1920), Palette16, 1.8),
'KoS': ("Kobo Sage", (1440, 1920), Palette16, 1.8),
'KoE': ("Kobo Elipsa", (1404, 1872), Palette16, 1.8),
'OTHER': ("Other", (0, 0), Palette16, 1.8),
Usage: kcc-c2e [options] comic_file|comic_folder
Options:
MAIN:
-p PROFILE, --profile=PROFILE
Device profile (Available options: K1, K2, K34, K578,
KDX, KPW, KPW5, KV, KO, K11, KS, KoMT, KoG, KoGHD,
KoA, KoAHD, KoAH2O, KoAO, KoN, KoC, KoL, KoF, KoS,
KoE) [Default=KV]
-m, --manga-style Manga style (right-to-left reading and splitting)
-q, --hq Try to increase the quality of magnification
-2, --two-panel Display two not four panels in Panel View mode
-w, --webtoon Webtoon processing mode
--targetsize=TARGETSIZE
the maximal size of output file in MB. [Default=100MB
for webtoon and 400MB for others]
OUTPUT SETTINGS:
-o OUTPUT, --output=OUTPUT
Output generated file to specified directory or file
-t TITLE, --title=TITLE
Comic title [Default=filename or directory name]
-f FORMAT, --format=FORMAT
Output format (Available options: Auto, MOBI, EPUB,
CBZ, KFX, MOBI+EPUB) [Default=Auto]
-b BATCHSPLIT, --batchsplit=BATCHSPLIT
Split output into multiple files. 0: Don't split 1:
Automatic mode 2: Consider every subdirectory as
separate volume [Default=0]
PROCESSING:
-n, --noprocessing Do not modify image and ignore any profil or
processing option
-u, --upscale Resize images smaller than device's resolution
-s, --stretch Stretch images to device's resolution
-r SPLITTER, --splitter=SPLITTER
Double page parsing mode. 0: Split 1: Rotate 2: Both
[Default=0]
-g GAMMA, --gamma=GAMMA
Apply gamma correction to linearize the image
[Default=Auto]
-c CROPPING, --cropping=CROPPING
Set cropping mode. 0: Disabled 1: Margins 2: Margins +
page numbers [Default=2]
--cp=CROPPINGP, --croppingpower=CROPPINGP
Set cropping power [Default=1.0]
--blackborders Disable autodetection and force black borders
--whiteborders Disable autodetection and force white borders
--forcecolor Don't convert images to grayscale
--forcepng Create PNG files instead JPEG
--mozjpeg Create JPEG files using mozJpeg
--maximizestrips Turn 1x4 strips to 2x2 strips
CUSTOM PROFILE:
--customwidth=CUSTOMWIDTH
Replace screen width provided by device profile
--customheight=CUSTOMHEIGHT
Replace screen height provided by device profile
OTHER:
-h, --help Show this help message and exit
Usage: kcc-c2p [options] comic_folder
Options:
MANDATORY:
-y HEIGHT, --height=HEIGHT
Height of the target device screen
-i, --in-place Overwrite source directory
-m, --merge Combine every directory into a single image before
splitting
OTHER:
-d, --debug Create debug file for every split image
-h, --help Show this help message and exit
KCC is made by Ciro Mattia Gonano, Paweł Jastrzębski and Darodi .
This script born as a cross-platform alternative to KindleComicParser by Dc5e (published here).
The app relies and includes the following scripts:
DualMetaFixscript by K. Hendricks. Released with GPL-3 License.image.pyclass from Alex Yatskov's Mangle with subsequent proDOOMman's and Birua's patches.- Icon is by Nikolay Verin (http://ncrow.deviantart.com/) and released under CC BY-NC-SA 3.0 License.
- Kindle Oasis 2 / 3
- Kindle Paperwhite 3 / 4 / Voyage / Oasis
- Kindle Paperwhite 1 / 2
- Kindle
- Kobo Aura
- Kobo Aura HD
- Kobo Aura H2O
- Kobo Aura ONE
- Kobo Forma
KCC is initiating internet connections in two cases:
- During startup - Version check.
- When error occurs - Automatic reporting on Windows and macOS.
Please check wiki page.
Copyright (c) 2012-2023 Ciro Mattia Gonano, Paweł Jastrzębski and Darodi.
KCC is released under ISC LICENSE; see LICENSE.txt for further details.