Ebook library which can handle EPUB2/EPUB3 and Kindle format
Project description
About EbookLib
==============
EbookLib is a Python library for managing EPUB2/EPUB3 and Kindle files. It's capable of reading and writing EPUB files programmatically (Kindle support is under development).
The API is designed to be as simple as possible, while at the same time making complex things possible too. It has support for covers, table of contents, spine, guide, metadata and etc.
EbookLib is used in [Booktype 2.0](https://github.com/sourcefabric/Booktype/) from Sourcefabric, as well as [sprits-it!](https://github.com/the-happy-hippo/sprits-it), [fanfiction2ebook](https://github.com/ltouroumov/fanfiction2ebook) and [deboutlesgens](https://github.com/vjousse/deboutlesgens).
Packages of EbookLib for GNU/Linux are available in [Debian](https://packages.debian.org/sid/python-ebooklib) and [Ubuntu](http://packages.ubuntu.com/utopic/python-ebooklib).
Sphinx documentation is generated from the templates in the docs/ directory and made available at http://ebooklib.readthedocs.org
Usage
=====
Reading
-------
from ebooklib import epub
book = epub.read_epub('test.epub')
for image in book.get_items_of_type(epub.ITEM_IMAGE):
print image
Writing
-------
from ebooklib import epub
book = epub.EpubBook()
# set metadata
book.set_identifier('id123456')
book.set_title('Sample book')
book.set_language('en')
book.add_author('Author Authorowski')
book.add_author('Danko Bananko', file_as='Gospodin Danko Bananko', role='ill', uid='coauthor')
# create chapter
c1 = epub.EpubHtml(title='Intro', file_name='chap_01.xhtml', lang='hr')
c1.content=u'<h1>Intro heading</h1><p>Žaba je skočila u baru.</p>'
# add chapter
book.add_item(c1)
# define Table Of Contents
book.toc = (epub.Link('chap_01.xhtml', 'Introduction', 'intro'),
(epub.Section('Simple book'),
(c1, ))
)
# add default NCX and Nav file
book.add_item(epub.EpubNcx())
book.add_item(epub.EpubNav())
# define CSS style
style = 'BODY {color: white;}'
nav_css = epub.EpubItem(uid="style_nav", file_name="style/nav.css", media_type="text/css", content=style)
# add CSS file
book.add_item(nav_css)
# basic spine
book.spine = ['nav', c1]
# write to the file
epub.write_epub('test.epub', book, {})
License
=======
EbookLib is licensed under the AGPL license.
Authors
=======
* Aleksandar Erkalovic <aerkalov@gmail.com>
* Borko Jandras <bjandras@gmail.com>
==============
EbookLib is a Python library for managing EPUB2/EPUB3 and Kindle files. It's capable of reading and writing EPUB files programmatically (Kindle support is under development).
The API is designed to be as simple as possible, while at the same time making complex things possible too. It has support for covers, table of contents, spine, guide, metadata and etc.
EbookLib is used in [Booktype 2.0](https://github.com/sourcefabric/Booktype/) from Sourcefabric, as well as [sprits-it!](https://github.com/the-happy-hippo/sprits-it), [fanfiction2ebook](https://github.com/ltouroumov/fanfiction2ebook) and [deboutlesgens](https://github.com/vjousse/deboutlesgens).
Packages of EbookLib for GNU/Linux are available in [Debian](https://packages.debian.org/sid/python-ebooklib) and [Ubuntu](http://packages.ubuntu.com/utopic/python-ebooklib).
Sphinx documentation is generated from the templates in the docs/ directory and made available at http://ebooklib.readthedocs.org
Usage
=====
Reading
-------
from ebooklib import epub
book = epub.read_epub('test.epub')
for image in book.get_items_of_type(epub.ITEM_IMAGE):
print image
Writing
-------
from ebooklib import epub
book = epub.EpubBook()
# set metadata
book.set_identifier('id123456')
book.set_title('Sample book')
book.set_language('en')
book.add_author('Author Authorowski')
book.add_author('Danko Bananko', file_as='Gospodin Danko Bananko', role='ill', uid='coauthor')
# create chapter
c1 = epub.EpubHtml(title='Intro', file_name='chap_01.xhtml', lang='hr')
c1.content=u'<h1>Intro heading</h1><p>Žaba je skočila u baru.</p>'
# add chapter
book.add_item(c1)
# define Table Of Contents
book.toc = (epub.Link('chap_01.xhtml', 'Introduction', 'intro'),
(epub.Section('Simple book'),
(c1, ))
)
# add default NCX and Nav file
book.add_item(epub.EpubNcx())
book.add_item(epub.EpubNav())
# define CSS style
style = 'BODY {color: white;}'
nav_css = epub.EpubItem(uid="style_nav", file_name="style/nav.css", media_type="text/css", content=style)
# add CSS file
book.add_item(nav_css)
# basic spine
book.spine = ['nav', c1]
# write to the file
epub.write_epub('test.epub', book, {})
License
=======
EbookLib is licensed under the AGPL license.
Authors
=======
* Aleksandar Erkalovic <aerkalov@gmail.com>
* Borko Jandras <bjandras@gmail.com>
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
EbookLib-0.15.tar.gz
(29.6 kB
view details)
File details
Details for the file EbookLib-0.15.tar.gz
.
File metadata
- Download URL: EbookLib-0.15.tar.gz
- Upload date:
- Size: 29.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | cba18893047b27cdc516ba61e05b76da5f087a3c3dd69c3121dda415fd3e9be1 |
|
MD5 | d29882a04477c3854b1af9f6a84dc160 |
|
BLAKE2b-256 | 04302cbf65fa9587a1ecc66a78eea91f9189ead8fdadd5e009115bce34529aa6 |