深入瞭解 EPUB 文件 | Linux 中國

語言: CN / TW / HK

EPUB 文件是使用開放格式發佈內容的好方法。

(本文字數:4515,閲讀時長大約:5 分鐘)

EPUB 文件是使用開放格式發佈內容的好方法。

電子書提供了一種隨時隨地閲讀書籍、雜誌和其他內容的好方法。讀者可以在長途飛行和乘坐火車時享受電子書打發時間。最流行的電子書文件格式是 EPUB 文件,它是“ 電子出版物(electronic publication) ”的縮寫。 EPUB 文件受到各種電子閲讀器的支持,並且是當今電子書出版的有效標準。

EPUB 文件格式基於 XHTML 內容和 XML 元數據的開放標準,包含在 zip 存檔中。由於一切都基於開放標準,我們可以使用通用工具來創建或檢查 EPUB 文件。讓我們探索一個 EPUB 文件以瞭解更多信息。《C 編程技巧和竅門指南》,於今年早些時候在Opensource.com 上發佈,提供 PDF 或 EPUB 格式。

因為 EPUB 文件是放在 zip 文件中的 XHTML 內容和 XML 元數據,所以你可以用 unzip 命令在命令行檢查 EPUB:

$ unzip -l osdc_Jim-Hall_C-Programming-Tips.epub 
Archive: osdc_Jim-Hall_C-Programming-Tips.epub
Length Date Time Name
--------- ---------- ----- ----
20 06-23-2022 00:20 mimetype
8259 06-23-2022 00:20 OEBPS/styles/stylesheet.css
1659 06-23-2022 00:20 OEBPS/toc.xhtml
4460 06-23-2022 00:20 OEBPS/content.opf
44157 06-23-2022 00:20 OEBPS/sections/section0018.xhtml
1242 06-23-2022 00:20 OEBPS/sections/section0002.xhtml
22429 06-23-2022 00:20 OEBPS/sections/section0008.xhtml
[...]
9628 06-23-2022 00:20 OEBPS/sections/section0016.xhtml
748 06-23-2022 00:20 OEBPS/sections/section0001.xhtml
3370 06-23-2022 00:20 OEBPS/toc.ncx
8308 06-23-2022 00:21 OEBPS/images/image0011.png
6598 06-23-2022 00:21 OEBPS/images/image0009.png
[...]
14492 06-23-2022 00:21 OEBPS/images/image0005.png
239 06-23-2022 00:20 META-INF/container.xml
--------- -------
959201 41 files

這個 EPUB 包含很多文件,但其中大部分是內容。要了解 EPUB 文件是如何組合在一起的,請遵循電子書閲讀器的流程:

1、電子書閲讀器需要驗證 EPUB 文件是否真的是 EPUB 文件。他們通過檢查 EPUB 存檔根目錄中的 mimetype 文件來驗證文件。該文件僅包含一行描述 EPUB 文件的 MIME 類型:

application/epub+zip

2、為了定位內容,電子書閲讀器從 META-INF/container.xml 文件開始。這是一個簡短的 XML 文檔,指示在哪裏可以找到內容。對於此 EPUB 文件, container.xml 文件如下所示:

<?xml version="1.0" encoding="UTF-8"?>
  <container version="1.0" xmlns="urn:oasis:names:tc:opendocument:xmlns:container">
    <rootfiles>
      <rootfile full-path="OEBPS/content.opf" media-type="application/oebps-package+xml"/>
  </rootfiles>
</container>

為了使 container.xml 文件更易於閲讀,我將單行拆分為多行,並添加了一些間距來縮進每行。XML 文件並不關心新行和空格等額外的空白,因此這種額外的間距不會影響 XML 文件。

3、 container.xml 文件表示 EPUB 的根從 OEBPS 目錄中的 content.opf 文件開始。OPF 擴展名是因為 EPUB 基於 “ 開放打包格式(Open Packaging Format) ”,但 content.opf 文件實際上只是另一個 XML 文件。

4、 content.opf 文件包含一個完整的 EPUB 內容清單,以及一個有序的目錄,以及查找每一章或每一節的引用。這個 EPUB 的 content.opf 文件很長,因此我將在此僅展示一小部分作為示例。

XML 數據包含在 <package> 塊中,該塊本身具有 <metadata> 塊、 <manifest> 數據和包含電子書目錄的 <spine> 塊:

<?xml version="1.0" encoding="UTF-8"?>
<package unique-identifier="unique-identifier" version="3.0" xmlns="http://www.idpf.org/2007/opf" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:dcterms="http://purl.org/dc/terms/" xmlns:opf="http://www.idpf.org/2007/opf">
  <metadata>
    <dc:identifier id="unique-identifier">osdc002</dc:identifier>
    <dc:title>Tips and Tricks for C Programming</dc:title>
    <dc:creator>Jim Hall</dc:creator>
    <dc:language>English</dc:language>
    <meta property="dcterms:modified">2022-06-23T12:09:13Z</meta>
    <meta content="LibreOffice/7.3.0.3$Linux_X86_64 LibreOffice_project/0f246aa12d0eee4a0f7adcefbf7c878fc2238db3 (libepubgen/0.1.1)" name="generator"/>
  </metadata>
  <manifest>
    ...
    <item href="sections/section0001.xhtml" id="section0001" media-type="application/xhtml+xml"/>
    <item href="images/image0003.png" id="image0003" media-type="image/png"/>
    <item href="styles/stylesheet.css" id="stylesheet.css" media-type="text/css"/>
    <item href="toc.ncx" id="toc.ncx" media-type="application/x-dtbncx+xml"/>
    ...
  </manifest>
  <spine toc="toc.ncx">
    <itemref idref="section0001"/>
    <itemref idref="section0002"/>
    <itemref idref="section0003"/>
    ...
  </spine>
</package>

你可以把數據匹配起來,看看在哪裏可以找到每個部分。EPUB 閲讀器就是這樣做的。例如,目錄中的第一項引用了 section0001 ,它在清單中被定義為位於 sections/section0001.xhtml 文件中。該文件的名稱不需要與 idref 條目相同,但 LibreOffice Writer 的自動程序就是這樣創建該文件的。(你可以在元數據中看到,這個 EPUB 是在 Linux 上用 LibreOffice 7.3.0.3 版本創建的,它可以將內容導出為 EPUB 文件。)

EPUB 格式

EPUB 文件是一種使用開放格式發佈內容的好方法。EPUB 文件格式是 XML 元數據與 XHTML 內容,包含在一個 zip 文件內。雖然大多數技術作家使用工具來創建 EPUB 文件,因為 EPUB 是基於開放標準,意味着你可以使用其他方式創建自己的 EPUB 文件。

via: https:// opensource.com/article/ 22/8/epub-file

作者:Jim Hall 選題: lkxed 譯者: geekpi 校對: wxy

本文由 LCTT 原創編譯,Linux中國 榮譽推出