溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

GitBook怎么制作電子書(shū)

發(fā)布時(shí)間:2021-07-02 11:19:44 來(lái)源:億速云 閱讀:176 作者:小新 欄目:開(kāi)發(fā)技術(shù)

這篇文章主要介紹了GitBook怎么制作電子書(shū),具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

gitbook安裝:

 https://nodejs.org/#download

下載node.js源代碼(點(diǎn)擊綠色的INSTALL),

解壓

./configure
make
make install

成功執(zhí)行后,npm就被安裝好了。

2. gitbook 安裝命令

npm install -g gitbook-cli


gitbook -V

查看gitbook是否安裝成功。

ref

===

1. wanqingwong.com/gitbook-zh/index.html

gitbook使用

===========

1. 根據(jù)目錄生成圖書(shū)結(jié)構(gòu)

1.1 README.md 與 SUMMARY編寫

README.md

這個(gè)文件相當(dāng)于一本Gitbook的簡(jiǎn)介。

$ mkdir test_gitbook
$ touch README.md

SUMMARY.md

這個(gè)文件是一本書(shū)的目錄結(jié)構(gòu),使用Markdown語(yǔ)法,

如我們這本書(shū)的SUMMARY.md:

$ touch SUMMARY.md
$ vim SUMMARY.md

輸入

* [簡(jiǎn)介](README.md)
* [第一章](chapter1/README.md)
 - [第一節(jié)](chapter1/section1.md)
 - [第二節(jié)](chapter1/section2.md)
* [第二章](chapter2/README.md)
 - [第一節(jié)](chapter2/section1.md)
 - [第二節(jié)](chapter2/section2.md)
* [結(jié)束](end/README.md)

1.2 生成圖書(shū)結(jié)構(gòu)

當(dāng)這個(gè)目錄文件創(chuàng)建好之后,我們可以使用Gitbook

的命令行工具將這個(gè)目錄結(jié)構(gòu)生成相應(yīng)的目錄及文件:

$ gitbook init
$ tree . #查看建立的目錄和文件

├── chapter1
│   ├── README.md
│   ├── section1.md
│   └── section2.md
├── chapter2
│   ├── README.md
│   ├── section1.md
│   └── section2.md
├── end
│   └── README.md
├── README.md
└── SUMMARY.md

我們可以看到,gitbook給我們生成了與SUMMARY.md所
對(duì)應(yīng)的目錄及文件。

每個(gè)目錄中,都有一個(gè)README.md文件,相當(dāng)于一章的說(shuō)明。

2. 生成圖書(shū)

2.1 輸出為靜態(tài)網(wǎng)站

你有兩種方式輸出一個(gè)靜態(tài)網(wǎng)站:

2.1.1 本地預(yù)覽時(shí)自動(dòng)生成

當(dāng)你在自己的電腦上編輯好圖書(shū)之后,你可以使用Gitbook
的命令行進(jìn)行本地預(yù)覽:

$ gitbook serve .

然后瀏覽器中輸入:

 http://localhost:4000

這樣就可以預(yù)覽生
成的以網(wǎng)頁(yè)形式組織的書(shū)籍。

這里你會(huì)發(fā)現(xiàn),你在你的圖書(shū)項(xiàng)目的目錄中多了一個(gè)名為
_book的文件目錄,而這個(gè)目錄中的文件,即是生成的靜態(tài)
網(wǎng)站內(nèi)容。

使用build參數(shù)生成到指定目錄

與直接預(yù)覽生成的靜態(tài)網(wǎng)站文件不一樣的是,使用這個(gè)命令,
你可以將內(nèi)容輸入到你所想要的目錄中去:

$ mkdir /tmp/gitbook
$ gitbook build --output=/tmp/gitbook

2.2 輸出PDF

輸入為PDF文件,需要先使用NPM安裝上gitbook pdf:

$ sudo npm install gitbook-pdf -g

我在執(zhí)行上面這條命令的時(shí)候出現(xiàn)了下面的錯(cuò)誤:

***************************************************

Downloading http://cdn.bitbucket.org/ariya/phantomjs/downloads/phantomjs-1.9.7-linux-i686.tar.bz2
Saving to /usr/local/lib/node_modules/gitbook-pdf/node_modules/phantomjs/phantomjs/phantomjs-1.9.7-linux-i686.tar.bz2
Error: connect ETIMEDOUT
  at exports._errnoException (util.js:746:11)
  at TCPConnectWrap.afterConnect [as oncomplete] (net.js:1010:19)
npm ERR! Linux 3.2.0-4-686-pae
npm ERR! argv "/usr/local/bin/node" "/usr/local/bin/npm" "install" "gitbook-pdf" "-g"
npm ERR! node v0.12.7
npm ERR! npm v2.11.3
npm ERR! code ELIFECYCLE


npm ERR! phantomjs@1.9.7-5 install: `node install.js`
npm ERR! Exit status 1
npm ERR!
npm ERR! Failed at the phantomjs@1.9.7-5 install script 'node install.js'.
npm ERR! This is most likely a problem with the phantomjs package,
npm ERR! not with npm itself.
npm ERR! Tell the author that this fails on your system:
npm ERR!   node install.js
npm ERR! You can get their info via:
npm ERR!   npm owner ls phantomjs
npm ERR! There is likely additional logging output above.


npm ERR! Please include the following file with any support request:
npm ERR!   /home/wangxq/repository/phantomjs/npm-debug.log

***************************************************

 由錯(cuò)誤報(bào)告內(nèi)容的第一行可以知道,發(fā)生錯(cuò)誤的原因是下載

 phantomjs發(fā)生了錯(cuò)誤,因此我們需要手動(dòng)下載和安裝。

 解決方法:[1]

$ git clone git://github.com/ariya/phantomjs.git
$ sudo apt-get install build-essential g++ flex bison gperf ruby perl \
 libsqlite3-dev libfontconfig1-dev libicu-dev libfreetype6 libssl-dev \
 libpng-dev libjpeg-dev python libx11-dev libxext-dev    #安裝編譯需要的工具和依賴
$ cd phantomjs
$ git checkout 1.9.7 #注意:這里的1.9.7是phantom的版本號(hào),可以由錯(cuò)誤報(bào)告的第一行找出 
$ ./build.sh --jobs 4
$ sudo cp bin/phantomjs /bin/
$ sudo npm install gitbook-pdf -g #重新進(jìn)行安裝

 然后,使用下面的命令,要PDF文件,首先安裝依賴庫(kù):

$ sudo apt-get install calibre 
$ gitbook -v 2.1.0 pdf .

 發(fā)生錯(cuò)誤:

*****************************************************

info: start conversion to pdf ....ERROR


Error: Command failed: /bin/sh -c ebook-convert /tmp/tmp-29384ctltwbk/SUMMARY.html /tmp/tmp-29384ctltwbk/index.pdf --title="" --comments="這本書(shū)是gitbook的一個(gè)例子" --language="en" --book-producer="GitBook" --publisher="GitBook" --chapter="descendant-or-self::*[contains(concat(' ', normalize-space(@class), ' '), ' book-chapter ')]" --chapter-mark="pagebreak" --page-breaks-before="/" --level1-toc="descendant-or-self::*[contains(concat(' ', normalize-space(@class), ' '), ' book-chapter-1 ')]" --level2-toc="descendant-or-self::*[contains(concat(' ', normalize-space(@class), ' '), ' book-chapter-2 ')]" --level3-toc="descendant-or-self::*[contains(concat(' ', normalize-space(@class), ' '), ' book-chapter-3 ')]" --no-chapters-in-toc --max-levels="1" --breadth-first --margin-left="62" --margin-right="62" --margin-top="56" --margin-bottom="56" --pdf-default-font-size="12" --pdf-mono-font-size="12" --paper-size="a4" --pdf-header-template="<p class='header'><span></span></p>" --pdf-footer-template="<p class='footer'><span>_SECTION_</span> <span style='float:right;'>_PAGENUM_</span></p>"
Usage: ebook-convert input_file output_file [options]


Convert an ebook from one format to another.


input_file is the input and output_file is the output. Both must be specified as the first two arguments to the command.


The output ebook format is guessed from the file extension of output_file. output_file can also be of the special format .EXT where EXT is the output file extension. In this case, the name of the output file is derived the name of the input file. Note that the filenames must not start with a hyphen. Finally, if output_file has no extension, then it is treated as a directory and an "open ebook" (OEB) consisting of HTML files is written to that directory. These files are the files that would normally have been passed to the output plugin.


After specifying the input and output file you can customize the conversion by specifying various options. The available options depend on the input and output file types. To get help on them specify the input and output file and then use the -h option.


For full documentation of the conversion system see
http://manual.calibre-ebook.com/conversion.html


Whenever you pass arguments to ebook-convert that have spaces in them, enclose the arguments in quotation marks.


ebook-convert: error: no such option: --pdf-default-font-size

*****************************************************

解決方法[2]

$ sudo -v && wget -nv -O- https://raw.githubusercontent.com/kovidgoyal/calibre/master/setup/linux-installer.py | sudo python -c "import sys; main=lambda:sys.stderr.write('Download failed\n'); exec(sys.stdin.read()); main()"


$ gitbook -v 2.1.0 pdf . # 重新執(zhí)行命令生成pdf,目標(biāo)文件為book.pdf

ref

===

1. http://phantomjs.org/build.html
2. http://calibre-ebook.com/download_linux

問(wèn)題

===

1. 如果輸入gitbook init命令,出現(xiàn)Installing version 2.1.0,

需要耐性等待安裝。

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“GitBook怎么制作電子書(shū)”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來(lái)學(xué)習(xí)!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI