EPUB::Parser - EPUB Parser class
use EPUB::Parser;
my $ep = EPUB::Parser->new;
# load epub
$ep->load_file({ file_path => 'sample.epub' });
# or
$ep->load_binary({ data => $binary_data })
# get opf version
my $version = $ep->opf->guess_version;
# get css. Return value is 'EPUB::Parser::Util::Archive::Iterator' object.
my $itr = $ep->items_by_media_type({ regexp => qr{text/css}ix });
while ( my $zip_member = $itr->next ) {
$zip_member->data;
$zip_member->path;
}
# shortcut method. iterator object contain image,audio,video item path.
my $itr = $ep->items_by_media;
# get list under <nav id="toc" epub:type="toc">
# todo: parse nested list
for my $chapter ( $ep->toc_list ) {
$chapter->{title};
$chapter->{href};
}
# get cover image blob
my $cover_img_path = $ep->opf->cover_image_path;
$ep->data_from_path($cover_img_path);
# get page list from each chapter.
my $collect_pages = $ep->pages_manager->get_page_from_each_chapter;
# no_chapter_member => [
# 'OEBPS/cover.xhtml',
# 'OEBPS/nav.xhtml'
# ],
# chapter_group => [
# [
# 'OEBPS/0_1.xhtml'
# 'OEBPS/0_2.xhtml'
# 'OEBPS/0_3.xhtml'
# ],
# [
# 'OEBPS/1_1.xhtml'
# 'OEBPS/1_2.xhtml'
# 'OEBPS/1_3.xhtml'
# ],
# ....
# ]
EPUB::Parser parse EPUB3 and return Perl Data Structure. This module can only parse EPUB3.
Constructor. Creates a new EPUB::Parser instance. Valid options are:
-
epub_version
EPUB::Parser->new({ epub_version => '3.0' }); epub_version is default 3.0 and current supoprt only 3.0.
Returns instance of EPUB::Parser::File::OPF.
Returns instance of EPUB::Parser::File::Navi.
get blob from loaded EPUB with path indicated in $path.
Returns instance of EPUB::Parser::Manager::Pages.
load from EPUB file.
load from EPUB blob.
Copyright (C) tokubass.
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
tokubass <tokubass {at} cpan.org>