Jupyter Notebook介紹、安裝及使用教程

一、什么是Jupyter Notebook?

1. 簡介

Jupyter Notebook是基于網頁的用于交互計算的應用程序。其可被應用于全過程計算:開發、文檔編寫、運行代碼和展示結果。——Jupyter Notebook官方介紹

簡而言之,Jupyter Notebook是以網頁的形式打開,可以在網頁頁面中直接編寫代碼運行代碼,代碼的運行結果也會直接在代碼塊下顯示的程序。如在編程過程中需要編寫說明文檔,可在同一個頁面中直接編寫,便于作及時的說明和解釋。

2. 組成部分

① 網頁應用

網頁應用即基于網頁形式的、結合了編寫說明文檔、數學公式、交互計算和其他富媒體形式的工具。簡言之,網頁應用是可以實現各種功能的工具。

② 文檔

即Jupyter Notebook中所有交互計算、編寫說明文檔、數學公式、圖片以及其他富媒體形式的輸入和輸出,都是以文檔的形式體現的。

這些文檔是保存為后綴名為.ipynbJSON格式文件,不僅便于版本控制,也方便與他人共享。

此外,文檔還可以導出為:HTML、LaTeX、PDF等格式。

3. Jupyter Notebook的主要特點

① 編程時具有語法高亮、縮進tab補全的功能。

② 可直接通過瀏覽器運行代碼,同時在代碼塊下方展示運行結果。

③ 以富媒體格式展示計算結果。富媒體格式包括:HTML,LaTeX,PNG,SVG等。

④ 對代碼編寫說明文檔或語句時,支持Markdown語法。

⑤ 支持使用LaTeX編寫數學性說明。

二、安裝Jupyter Notebook

0. 先試用,再決定

如果看了以上對Jupyter Notebook的介紹你還是拿不定主意究竟是否適合你,那么不要擔心,你可以先免安裝試用體驗一下,戳這里,然后再做決定。

值得注意的是,官方提供的同時試用是有限的,如果你點擊鏈接之后進入的頁面如下圖所示,那么不要著急,過會兒再試試看吧。

image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">試用滿線</figcaption>

如果你足夠幸運,那么你將看到如下界面,就可以開始體驗啦。

image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">主界面</figcaption>

image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">編輯頁面</figcaption>

1. 安裝

① 安裝前提

安裝Jupyter Notebook的前提是需要安裝了Python(3.3版本及以上,或2.7版本)。

② 使用Anaconda安裝

如果你是小白,那么建議你通過安裝Anaconda來解決Jupyter Notebook的安裝問題,因為Anaconda已經自動為你安裝了Jupter Notebook及其他工具,還有python中超過180個科學包及其依賴項。

你可以通過進入Anaconda的官方下載頁面自行選擇下載;如果你對閱讀英文文檔感到頭痛,或者對安裝步驟一無所知,甚至也想快速了解一下什么是Anaconda,那么可以前往我的另一篇文章:

豆豆:Anaconda介紹、安裝及使用教程?zhuanlan.zhihu.com

你想要的,都在里面!

常規來說,安裝了Anaconda發行版時已經自動為你安裝了Jupyter Notebook的,但如果沒有自動安裝,那么就在終端(Linux或macOS的“終端”,Windows的“Anaconda Prompt”,以下均簡稱“終端”)中輸入以下命令安裝:

conda install jupyter notebook

③ 使用pip命令安裝

如果你是有經驗的Python玩家,想要嘗試用pip命令來安裝Jupyter
Notebook,那么請看以下步驟吧!接下來的命令都輸入在終端當中的噢!

1. 把pip升級到最新版本

  • Python 3.x
pip3 install --upgrade pip
  • Python 2.x
pip install --upgrade pip
  • 注意:老版本的pip在安裝Jupyter Notebook過程中或面臨依賴項無法同步安裝的問題。因此強烈建議先把pip升級到最新版本。

2. 安裝Jupyter Notebook

  • Python 3.x
pip3 install jupyter
  • Python 2.x
pip install jupyter

三、運行Jupyter Notebook

0. 幫助

如果你有任何jupyter notebook命令的疑問,可以考慮查看官方幫助文檔,命令如下:

jupyter notebook --help

jupyter notebook -h

1. 啟動

① 默認端口啟動

在終端中輸入以下命令:

jupyter notebook

執行命令之后,在終端中將會顯示一系列notebook的服務器信息,同時瀏覽器將會自動啟動Jupyter Notebook。

啟動過程中終端顯示內容如下:

$ jupyter notebook
[I 08:58:24.417 NotebookApp] Serving notebooks from local directory: /Users/catherine
[I 08:58:24.417 NotebookApp] 0 active kernels
[I 08:58:24.417 NotebookApp] The Jupyter Notebook is running at: http://localhost:8888/
[I 08:58:24.417 NotebookApp] Use Control-C to stop this server and shut down all kernels (twice to skip confirmation).
  • 注意:之后在Jupyter Notebook的所有操作,都請保持終端不要關閉,因為一旦關閉終端,就會斷開與本地服務器的鏈接,你將無法在Jupyter Notebook中進行其他操作啦。

瀏覽器地址欄中默認地將會顯示:http://localhost:8888。其中,“localhost”指的是本機,“8888”則是端口號。

image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">URL</figcaption>

如果你同時啟動了多個Jupyter Notebook,由于默認端口“8888”被占用,因此地址欄中的數字將從“8888”起,每多啟動一個Jupyter Notebook數字就加1,如“8889”、“8890”……

② 指定端口啟動

如果你想自定義端口號來啟動Jupyter Notebook,可以在終端中輸入以下命令:

jupyter notebook --port <port_number>

其中,“<port_number>”是自定義端口號,直接以數字的形式寫在命令當中,數字兩邊不加尖括號“<>”。如:jupyter notebook --port 9999,即在端口號為“9999”的服務器啟動Jupyter Notebook。

③ 啟動服務器但不打開瀏覽器

如果你只是想啟動Jupyter Notebook的服務器但不打算立刻進入到主頁面,那么就無需立刻啟動瀏覽器。在終端中輸入:

jupyter notebook --no-browser

此時,將會在終端顯示啟動的服務器信息,并在服務器啟動之后,顯示出打開瀏覽器頁面的鏈接。當你需要啟動瀏覽器頁面時,只需要復制鏈接,并粘貼在瀏覽器的地址欄中,輕按回車變轉到了你的Jupyter Notebook頁面。

image

例圖中由于在完成上面內容時我同時啟動了多個Jupyter Notebook,因此顯示我的“8888”端口號被占用,最終分配給我的是“8889”。

2. 主頁面

① 主頁面內容

當執行完啟動命令之后,瀏覽器將會進入到Notebook的主頁面,如下圖所示。

image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">默認主頁面</figcaption>

如果你的主頁面里邊的文件夾跟我的不同,或者你在疑惑為什么首次啟動里邊就已經有這么多文件夾,不要擔心,這里邊的文件夾全都是你的家目錄里的目錄文件。你可以在終端中執行以下2步來查看:

cdcd -cd ~cd /Users/<user_name>

  • 這個命令將會進入你的家目錄。
  • “<user_name>” 是用戶名。用戶名兩邊不加尖括號“<>”。

ls

  • 這個命令將會展示你家目錄下的文件。

② 設置Jupyter Notebook文件存放位置

如果你不想把今后在Jupyter Notebook中編寫的所有文檔都直接保存在家目錄下,那你需要修改Jupyter Notebook的文件存放路徑。

⑴ 創建文件夾/目錄

  • Windows用戶在想要存放Jupyter Notebook文件的磁盤新建文件夾并為該文件夾命名;雙擊進入該文件夾,然后復制地址欄中的路徑。
  • Linux/macOS用戶在想要存放Jupyter Notebook文件的位置創建目錄并為目錄命名,命令為:mkdir <directory_name>;進入目錄,命令為:cd <directory_name>;查看目錄的路徑,命令為:pwd;復制該路徑。
  • 注意:“<directory_name>”是自定義的目錄名。目錄名兩邊不加尖括號“<>”。

⑵ 配置文件路徑

  • 一個便捷獲取配置文件所在路徑的命令:
jupyter notebook --generate-config
  • 注意: 這條命令雖然可以用于查看配置文件所在的路徑,但主要用途是是否將這個路徑下的配置文件替換默認配置文件。 如果你是第一次查詢,那么或許不會出現下圖的提示;若文件已經存在或被修改,使用這個命令之后會出現詢問“Overwrite /Users/raxxie/.jupyter/jupyter_notebook_config.py with default config? [y/N]”,即“用默認配置文件覆蓋此路徑下的文件嗎?”,如果按“y”,則完成覆蓋,那么之前所做的修改都將失效;如果只是為了查詢路徑,那么一定要輸入“N”。
image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">配置文件所在路徑</figcaption>

常規的情況下,Windows和Linux/macOS的配置文件所在路徑和配置文件名如下所述:

  • Windows系統的配置文件路徑:C:\Users\<user_name>\.jupyter\
  • Linux/macOS系統的配置文件路徑:/Users/<user_name>/.jupyter/~/.jupyter/
  • 配置文件名:jupyter_notebook_config.py

注意:

① “<user_name>”為你的用戶名。用戶名兩邊不加尖括號“<>”。

② Windows和Linux/macOS系統的配置文件存放路徑其實是相同的,只是系統不同,表現形式有所不同而已。

③ Windows和Linux/macOS系統的配置文件也是相同的。文件名以“.py”結尾,是Python的可執行文件。

④ 如果你不是通過一步到位的方式前往配置文件所在位置,而是一層一層進入文件夾/目錄的,那么當你進入家目錄后,用ls命令會發現找不到“.jupyter”文件夾/目錄。這是因為凡是以“.”開頭的目錄都是隱藏文件,你可以通過ls -a命令查看當前位置下所有的隱藏文件。

⑶ 修改配置文件

  • Windows系統的用戶可以使用文檔編輯工具或IDE打開“jupyter_notebook_config.py”文件并進行編輯。常用的文檔編輯工具和IDE有記事本、Notepad++、vim、Sublime
    Text、PyCharm等。其中,vim是沒有圖形界面的,是一款學習曲線較為陡峭的編輯器,其他工具在此不做使用說明,因為上手相對簡單。通過vim修改配置文件的方法請繼續往下閱讀。
  • Linux/macOS系統的用戶建議直接通過終端調用vim來對配置文件進行修改。具體操作步驟如下:

? 打開配置文件

打開終端,輸入命令:

vim ~/.jupyter/jupyter_notebook_config.py
image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">命令詳解</figcaption>

執行上述命令后便進入到配置文件當中了。

? 查找關鍵詞

進入配置文件后查找關鍵詞“c.NotebookApp.notebook_dir”。查找方法如下:

進入配置文件后不要按其他鍵,用英文半角直接輸入/c.NotebookApp.notebook_dir,這時搜索的關鍵詞已在文檔中高亮顯示了,按回車,光標從底部切換到文檔正文中被查找關鍵詞的首字母。

? 編輯配置文件

小寫i進入編輯模式,底部出現“--INSERT--”說明成功進入編輯模式。使用方向鍵把光標定位在第二個單引號上(光標定位在哪個字符,就在這個字符前開始輸入),把“⑴ 創建文件夾/目錄”步驟中復制的路徑粘貼在此處。

? 取消注釋

把該行行首的井號(#)刪除。因為配置文件是Python的可執行文件,在Python中,井號(#)表示注釋,即在編譯過程中不會執行該行命令,所以為了使修改生效,需要刪除井號(#)。

? 保存配置文件

先按esc鍵,從編輯模式退出,回到命令模式。

再用英文半角直接輸入:wq,回車即成功保存且退出了配置文件。

注意:

  • 冒號(:) 一定要有,且也是英文半角。
  • w:保存。
  • q:退出。

? 驗證

在終端中輸入命令jupyter notebook打開Jupyter Notebook,此時你會看到一個清爽的界面,恭喜!

image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">配置后主頁面</figcaption>

? 注意

  • 以上所有命令均以英文半角格式輸入,若有報錯,請嚴格檢查這兩個條件,英文半角
  • 這里僅介紹了vim編輯器修改配置文件的方法,沒有對vim編輯器的詳細使用進行講解,所以無需了解vim編輯器的具體使用方法,只需要按照上述步驟一定可以順利完成修改!
  • 推薦有時間和經歷時學習一下vim編輯器的使用。這款強大的編輯器將會成為你未來工作中的利器。

四、Jupyter Notebook的基本使用

1. Files頁面

image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">Files頁面</figcaption>

此時你的界面當中應該還沒有“Conda”和“Nbextensions”類目。不要著急,這兩個類目將分別在“五、拓展功能”中的“1.關聯Jupyter Notebook和conda的環境和包——‘nb_conda’”和“2.Markdown生成目錄”中安裝。

Files頁面是用于管理和創建文件相關的類目。

對于現有的文件,可以通過勾選文件的方式,對選中文件進行復制、重命名、移動、下載、查看、編輯和刪除的操作。

同時,也可以根據需要,在“New”下拉列表中選擇想要創建文件的環境,進行創建“ipynb”格式的筆記本、“txt”格式的文檔、終端或文件夾。如果你創建的環境沒有在下拉列表中顯示,那么你需要依次前往“五、拓展功能”中的“1.關聯Jupyter Notebook和conda的環境和包——‘nb_conda’”和“六、增加內核——‘ipykernel’”中解決該問題。

① 筆記本的基本操作

image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">筆記本頁面注解圖</figcaption>

上圖展示的是筆記本的基本結構和功能。根據圖中的注解已經可以解決絕大多數的使用問題了!

工具欄的使用如圖中的注解一樣直觀,在此不過多解釋。需要特別說明的是“單元格的狀態”,有Code,Markdown,Heading,Raw NBconvert。其中,最常用的是前兩個,分別是代碼狀態,Markdown編寫狀態。Jupyter Notebook已經取消了Heading狀態,即標題單元格。取而代之的是Markdown的一級至六級標題。而Raw NBconvert目前極少用到,此處也不做過多講解。

菜單欄涵蓋了筆記本的所有功能,即便是工具欄的功能,也都可以在菜單欄的類目里找到。然而,并不是所有功能都是常用的,比如Widgets,Navigate。Kernel類目的使用,主要是對內核的操作,比如中斷、重啟、連接、關閉、切換內核等,由于我們在創建筆記本時已經選擇了內核,因此切換內核的操作便于我們在使用筆記本時切換到我們想要的內核環境中去。由于其他的功能相對比較常規,根據圖中的注解來嘗試使用筆記本的功能已經非常便捷,因此不再做詳細講解。

② 筆記本重命名的兩種方式

⑴ 筆記本內部重命名

在使用筆記本時,可以直接在其內部進行重命名。在左上方“Jupyter”的圖標旁有程序默認的標題“Untitled”,點擊“Untitled”然后在彈出的對話框中輸入自擬的標題,點擊“Rename”即完成了重命名。

⑵ 筆記本外部重命名

若在使用筆記本時忘記了重命名,且已經保存并退出至“Files”界面,則在“Files”界面勾選需要重命名的文件,點擊“Rename”然后直接輸入自擬的標題即可。

⑶ 演示

image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">筆記本重命名演示圖</figcaption>

2. Running頁面

Running頁面主要展示的是當前正在運行當中的終端和“ipynb”格式的筆記本。若想要關閉已經打開的終端和“ipynb”格式的筆記本,僅僅關閉其頁面是無法徹底退出程序的,需要在Running頁面點擊其對應的“Shutdown”。更多關閉方法可以查閱“八、關閉和退出”中的“1.關閉筆記本和終端”。

image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">Running頁面功能演示圖</figcaption>

3. Clusters頁面

Clusters tab is now provided by IPython parallel. See 'IPython parallel' for
installation details.

Clusters類目現在已由IPython parallel對接,且由于現階段使用頻率較低,因此在此不做詳細說明,想要了解更多可以訪問IPython parallel的官方網站

4. Conda頁面

Conda頁面主要是Jupyter Notebook與Conda關聯之后對Conda環境和包進行直接操作和管理的頁面工具。詳細信息請直接查閱“五、拓展功能”中的“1.關聯Jupyter Notebook和conda的環境和包——‘nb_conda’”。這是目前使用Jupyter Notebook的必備環節,因此請務必查閱。

5. Nbextensions頁面

Nbextensions頁面提供了多個Jupyter Notebook的插件,使其功能更加強大。該頁面中主要使用的插件有nb_conda,nb_present,Table of Contents(2)。這些功能我們無需完全掌握,也無需安裝所有的擴展功能,根據本文檔提供的學習思路,我們只需要安裝Talbe of Contents(2)即可,該功能可為Markdown文檔提供目錄導航,便于我們編寫文檔。該安裝指導請查閱“五、拓展功能”中的“2.Markdown生成目錄”。

image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">Nbextensions頁面</figcaption>

五、拓展功能

1. 關聯Jupyter Notebook和conda的環境和包——“nb_conda”☆

① 安裝

conda install nb_conda

執行上述命令能夠將你conda創建的環境與Jupyter Notebook相關聯,便于你在Jupyter Notebook的使用中,在不同的環境下創建筆記本進行工作。

② 使用

  • 可以在Conda類目下對conda環境和包進行一系列操作。
image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">Conda頁面注解圖</figcaption>

  • 可以在筆記本內的“Kernel”類目里的“Change
    kernel”切換內核。
image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">切換內核</figcaption>

③ 卸載

canda remove nb_conda

執行上述命令即可卸載nb_conda包。

2. Markdown生成目錄

  • 不同于有道云筆記的Markdown編譯器,Jupyter Notebook無法為Markdown文檔通過特定語法添加目錄,因此需要通過安裝擴展來實現目錄的添加。
conda install -c conda-forge jupyter_contrib_nbextensions
  • 執行上述命令后,啟動Jupyter Notebook,你會發現導航欄多了“Nbextensions”的類目,點擊“Nbextensions”,勾選“Table
    of Contents ⑵”
image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">Nbextensions頁面</figcaption>

  • 之后再在Jupyter Notebook中使用Markdown,點擊下圖的圖標即可使用啦。
image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">目錄</figcaption>

3. Markdown在文中設置鏈接并定位

在使用Markdown編輯文檔時,難免會遇到需要在文中設定鏈接,定位在文檔中的其他位置便于查看。因為Markdown可以完美的兼容html語法,因此這種功能可以通過html語法當中“a標簽”的索引用法來實現。

語法格式如下:

[添加鏈接的正文](#自定義索引詞)
<a id=自定義索引詞>跳轉提示</a>

注意:

  1. 語法格式當中所有的符號均是英文半角
  2. “自定義索引詞”最好是英文,較長的詞可以用下劃線連接。
  3. “a標簽”出現在想要被跳轉到的文章位置,html標簽除了單標簽外均要符合“有頭(<a>)必有尾(</a>)”的原則。頭尾之間的“跳轉提示”是可有可無的。
  4. “a標簽”中的“id”值即是為正文中添加鏈接時設定的“自定義索引值”,這里通過“id”的值實現從正文的鏈接跳轉至指定位置的功能。

例:

image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">有跳轉提示語</figcaption>

image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">無跳轉提示語</figcaption>

4. 加載指定網頁源代碼

① 使用場景

想要在Jupyter Notebook中直接加載指定網站的源代碼到筆記本中。

② 方法

執行以下命令:

%load URL

其中,URL為指定網站的地址。

③ 例

image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">加載網絡代碼</figcaption>

5. 加載本地Python文件

① 使用場景

想在Jupyter Notebook中加載本地的Python文件并執行文件代碼。

② 方法

執行以下命令:

%load Python文件的絕對路徑

③ 注意

  1. Python文件的后綴為“.py”。
  2. “%load”后跟的是Python文件的絕對路徑。
  3. 輸入命令后,可以按CTRL 回車來執行命令。第一次執行,是將本地的Python文件內容加載到單元格內。此時,Jupyter Notebook會自動將“%load”命令注釋掉(即在前邊加井號“#”),以便在執行已加載的文件代碼時不重復執行該命令;第二次執行,則是執行已加載文件的代碼。

④ 例

image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">加載本地Python文件</figcaption>

6. 直接運行本地Python文件

① 使用場景

不想在Jupyter Notebook的單元格中加載本地Python文件,想要直接運行。

② 方法

執行命令:

%run Python文件的絕對路徑

!python3 Python文件的絕對路徑

!python Python文件的絕對路徑

③ 注意

  1. Python文件的后綴為“.py”。
  2. “%run”后跟的是Python文件的絕對路徑。
  3. “!python3”用于執行Python
    3.x版本的代碼。
  4. “!python”用于執行Python
    2.x版本的代碼。
  5. “!python3”和“!python”屬于 !shell命令 語法的使用,即在Jupyter Notebook中執行shell命令的語法。
  6. 輸入命令后,可以按 control return 來執行命令,執行過程中將不顯示本地Python文件的內容,直接顯示運行結果。

④ 例

image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">運行本地Python文件</figcaption>

7. 在Jupyter Notebook中獲取當前位置

① 使用場景

想要在Jupyter Notebook中獲取當前所在位置的絕對路徑。

② 方法

%pwd

!pwd

③ 注意

  1. 獲取的位置是當前Jupyter Notebook中創建的筆記本所在位置,且該位置為絕對路徑。
  2. “!pwd”屬于 !shell命令 語法的使用,即在Jupyter
    Notebook中執行shell命令的語法。

④ 例

image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">獲取當前位置的絕對路徑</figcaption>

8. 在Jupyter Notebook使用shell命令

① 方法一——在筆記本的單元格中

⑴ 語法

!shell命令
  • 在Jupyter Notebook中的筆記本單元格中用英文感嘆號“!”后接shell命令即可執行shell命令。

⑵ 例

image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">Shell命令的使用</figcaption>

② 方法二——在Jupyter Notebook中新建終端

⑴ 啟動方法

在Jupyter Notebook主界面,即“File”界面中點擊“New”;在“New”下拉框中點擊“Terminal”即新建了終端。此時終端位置是在你的家目錄,可以通過pwd命令查詢當前所在位置的絕對路徑。

⑵ 關閉方法

在Jupyter Notebook的“Running”界面中的“Terminals”類目中可以看到正在運行的終端,點擊后邊的“Shutdown”即可關閉終端。

⑶ 例

image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">筆記本中的終端使用</figcaption>

9. 隱藏筆記本輸入單元格

① 使用場景

在Jupyter Notebook的筆記本中無論是編寫文檔還是編程,都有輸入(In [])和輸出(Out [])。當我們編寫的代碼或文檔使用的單元格較多時,有時我們只想關注輸出的內容而暫時不看輸入的內容,這時就需要隱藏輸入單元格而只顯示輸出單元格。

② 方法一

⑴ 代碼

from IPython.display import display
from IPython.display import HTML
import IPython.core.display as di # Example: di.display_html('<h3>%s:</h3>' % str, raw=True)

# 這行代碼的作用是:當文檔作為HTML格式輸出時,將會默認隱藏輸入單元格。
di.display_html('<script>jQuery(function() {if (jQuery("body.notebook_app").length == 0) { jQuery(".input_area").toggle(); jQuery(".prompt").toggle();}});</script>', raw=True)

# 這行代碼將會添加“Toggle code”按鈕來切換“隱藏/顯示”輸入單元格。
di.display_html('''<button onclick="jQuery('.input_area').toggle(); jQuery('.prompt').toggle();">Toggle code</button>''', raw=True)

在筆記本第一個單元格中輸入以上代碼,然后執行,即可在該文檔中使用“隱藏/顯示”輸入單元格功能。

  • 缺陷:此方法不能很好的適用于Markdown單元格。

⑵ 例

image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">方法一:隱藏/顯示輸入單元格</figcaption>

③ 方法二

⑴ 代碼

from IPython.display import HTML

HTML('''<script>
code_show=true; 
function code_toggle() {
if (code_show){
$('div.input').hide();
} else {
$('div.input').show();
}
code_show = !code_show
} 
$( document ).ready(code_toggle);
</script>
<form action="javascript:code_toggle()"><input type="submit" value="Click here to toggle on/off the raw code."></form>''')

在筆記本第一個單元格中輸入以上代碼,然后執行,即可在該文檔中使用“隱藏/顯示”輸入單元格功能。

  • 缺陷:此方法不能很好的適用于Markdown單元格。

⑵ 例

image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">方法二:隱藏/顯示輸入單元格</figcaption>

10. 魔術命令

由于目前暫時用不到過多的魔術命令,因此暫時先參考官網的文檔。

六、增加內核——“ipykernel” ☆

1. 使用場景

  • 場景一:同時用不同版本的Python進行工作,在Jupyter Notebook中無法切換,即“New”的下拉菜單中無法使用需要的環境。
  • 場景二:創建了不同的虛擬環境(或許具有相同的Python版本但安裝的包不同),在Jupyter Notebook中無法切換,即“New”的下拉菜單中無法使用需要的環境。

接下來將分別用“命令行模式”和“圖形界面模式”來解決以上兩個場景的問題。顧名思義,“命令行模式”即在終端中通過執行命令來一步步解決問題;“圖形界面模式”則是通過在Jupyter Notebook的網頁中通過鼠標點擊的方式解決上述問題。

其中,“圖形界面模式”的解決方法相對比較簡單快捷,如果對于急于解決問題,不需要知道運行原理的朋友,可以直接進入“3. 解決方法之圖形界面模式”來閱讀。

“命令行模式”看似比較復雜,且又劃分了使用場景,但通過這種方式來解決問題可以更好的了解其中的工作原理,比如,每進行一步操作對應的命令是什么,而命令的執行是為了達到什么樣的目的,這些可能都被封裝在圖形界面上的一個點擊動作來完成了。對于想更深入了解其運作過程的朋友,可以接著向下閱讀。

2. 解決方法之命令行模式

① 同時使用不同版本的Python

⑴ 在Python 3中創建Python 2內核

? pip安裝

  • 首先安裝Python 2的ipykernel包。
python2 -m pip install ipykernel
  • 再為當前用戶安裝Python 2的內核(ipykernel)。
python2 -m ipykernel install --user
  • 注意:“--user”參數的意思是針對當前用戶安裝,而非系統范圍內安裝。

? conda安裝

  • 首先創建Python版本為2.x且具有ipykernel的新環境,其中“<env_name>”為自定義環境名,環境名兩邊不加尖括號“<>”。
conda create -n <env_name> python=2 ipykernel
  • 然后切換至新創建的環境。
Windows: activate <env_name>
Linux/macOS: source activate <env_name>
  • 當前用戶安裝Python 2的內核(ipykernel)。
python2 -m ipykernel install --user
  • 注意:“--user”參數的意思是針對當前用戶安裝,而非系統范圍內安裝。

⑵ 在Python 2中創建Python 3內核

? pip安裝

  • 首先安裝Python 3的ipykernel包。
python3 -m pip install ipykernel
  • 再為當前用戶安裝Python 2的內核(ipykernel)。
python3 -m ipykernel install --user
  • 注意:“--user”參數的意思是針對當前用戶安裝,而非系統范圍內安裝。

? conda安裝

  • 首先創建Python版本為3.x且具有ipykernel的新環境,其中“<env_name>”為自定義環境名,環境名兩邊不加尖括號“<>”。
conda create -n <env_name> python=3 ipykernel
  • 然后切換至新創建的環境。
Windows: activate <env_name>
Linux/macOS: source activate <env_name>
  • 當前用戶安裝Python 3的內核(ipykernel)。
python3 -m ipykernel install --user
  • 注意:“--user”參數的意思是針對當前用戶安裝,而非系統范圍內安裝。

② 為不同環境創建內核

⑴ 切換至需安裝內核的環境

Windows: activate <env_name>
Linux/macOS: source activate <env_name>
  • 注意:“<env_name>”是需要安裝內核的環境名稱,環境名兩邊不加尖括號“<>”。

⑵ 檢查該環境是否安裝了ipykernel包

conda list

執行上述命令查看當前環境下安裝的包,若沒有安裝ipykernel包,則執行安裝命令;否則進行下一步。

conda install ipykernel

⑶ 為當前環境下的當前用戶安裝Python內核

  • 若該環境的Python版本為2.x,則執行命令:
python2 -m ipykernel install --user --name <env_name> --display-name "<notebook_name>"
  • 若該環境的Python版本為3.x,則執行命令:
python3 -m ipykernel install --user --name <env_name> --display-name "<notebook_name>"
  • 注意:

1. “<env_name>”為當前環境的環境名稱。環境名兩邊不加尖括號“<>”。

2. “<notebook_name>”為自定義顯示在Jupyter Notebook中的名稱。名稱兩邊不加尖括號“<>”,但雙引號必須加

3. “--name”參數的值,即“<env_name>”是Jupyter內部使用的,其目錄的存放路徑為~/Library/Jupyter/kernels/。如果定義的名稱在該路徑已經存在,那么將自動覆蓋該名稱目錄的內容。

4. “--display-name”參數的值是顯示在Jupyter Notebook的菜單中的名稱。

⑷ 檢驗

使用命令jupyter notebook啟動Jupyter Notebook;在“Files”下的“New”下拉框中即可找到你在第⑶步中的自定義名稱,此時,你便可以盡情地在Jupyter Notebook中切換環境,在不同的環境中創建筆記本進行工作和學習啦!

3. 解決方法之圖形界面模式

① 你創建了一個新的環境,但卻發現在Jupyter Notebook的“New”中找不到這個環境,無法在該環境中創建筆記本。

image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">問題發現</figcaption>

② 進入Jupyter Notebook → Conda → 在“Conda
environment”中點擊你要添加ipykernel包的環境 → 左下方搜索框輸入“ipykernel”
→ 勾選“ipykernel” → 點擊搜索框旁的“→”箭頭 → 安裝完畢 → 右下方框內找到“ipykernel”說明已經安裝成功

image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">解決方法</figcaption>

③ 在終端control c關閉Jupyter Notebook的服務器然后重啟Jupyter Notebook,在“File”的“New”的下拉列表里就可以找到你的環境啦。

image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">驗證</figcaption>

七、Jupyter Notebook快捷鍵

1. Mac與Windows特殊按鍵對照表

image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">Mac和Windows特殊按鍵對照表</figcaption>

2. Jupyter Notebook筆記本的兩種模式

① 命令模式

  • 命令模式將鍵盤命令與Jupyter Notebook筆記本命令相結合,可以通過鍵盤不同鍵的組合運行筆記本的命令。
  • esc鍵進入命令模式。
  • 命令模式下,單元格邊框為灰色,且左側邊框線為藍色粗線條。
image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">命令模式</figcaption>

② 編輯模式

  • 編輯模式使用戶可以在單元格內編輯代碼或文檔。
  • enterreturn鍵進入編輯模式。
  • 編輯模式下,單元格邊框和左側邊框線均為綠色。
image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">編輯模式</figcaption>

3. 兩種模式的快捷鍵

① 命令模式

image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">命令模式快捷鍵</figcaption>

② 編輯模式

image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">編輯模式快捷鍵</figcaption>

4. 查看和編輯快捷鍵

① 查看快捷鍵

① 進入Jupyter Notebook主界面“File”中。

② 在“New”的下拉列表中選擇環境創建一個筆記本。

③ 點擊“Help”。

④ 點擊“Keyboard Shortcuts”。

② 編輯快捷鍵

⑴ 方法一

① 進入Jupyter Notebook主界面“File”中。

② 在“New”的下拉列表中選擇環境創建一個筆記本。

③ 點擊“Help”。

④ 點擊“Keyboard Shortcuts”。

⑤ 彈出的對話框中“Command Mode (press Esc to enable)”旁點擊“Edit
Shortcuts”按鈕。

⑵ 方法二

① 進入Jupyter Notebook主界面“File”中。

② 在“New”的下拉列表中選擇環境創建一個筆記本。

③ 點擊“Help”。

④ 點擊“Edit Keyboard Shortcuts”。

③ 例

image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">查看和編輯快捷鍵</figcaption>

八、關閉和退出

1. 關閉筆記本和終端

當我們在Jupyter Notebook中創建了終端或筆記本時,將會彈出新的窗口來運行終端或筆記本。當我們使用完畢想要退出終端或筆記本時,僅僅關閉頁面是無法結束程序運行的,因此我們需要通過以下步驟將其完全關閉。

① 方法一

⑴ 進入“Files”頁面。

⑵ 勾選想要關閉的“ipynb”筆記本。正在運行的筆記本其圖標為綠色,且后邊標有“Running”的字樣;已經關閉的筆記本其圖標為灰色。

⑶ 點擊上方的黃色的“Shutdown”按鈕。

⑷ 成功關閉筆記本。

  • 注意:此方法只能關閉筆記本,無法關閉終端。

② 方法二

⑴ 進入“Running”頁面。

⑵ 第一欄是“Terminals”,即所有正在運行的終端均會在此顯示;第二欄是“Notebooks”,即所有正在運行的“ipynb”筆記本均會在此顯示。

⑶ 點擊想要關閉的終端或筆記本后黃色“Shutdown”按鈕。

⑷ 成功關閉終端或筆記本。

  • 注意:此方法可以關閉任何正在運行的終端和筆記本。

③ 注意

⑴ 只有“ipynb”筆記本和終端需要通過上述方法才能使其結束運行。


“txt”文檔,即“New”下拉列表中的“Text
File”,以及“Folder”只要關閉程序運行的頁面即結束運行,無需通過上述步驟關閉。

④ 演示

image

<figcaption style="margin-top: 0.66667em; padding: 0px 1em; font-size: 0.9em; line-height: 1.5; text-align: center; color: rgb(153, 153, 153);">關閉筆記本或終端程序</figcaption>

2. 退出Jupyter Notebook程序

如果你想退出Jupyter Notebook程序,僅僅通過關閉網頁是無法退出的,因為當你打開Jupyter Notebook時,其實是啟動了它的服務器。

你可以嘗試關閉頁面,并打開新的瀏覽器頁面,把之前的地址輸進地址欄,然后跳轉頁面,你會發現再次進入了剛才“關閉”的Jupyter Notebook頁面。

如果你忘記了剛才關閉的頁面地址,可以在啟動Jupyter Notebook的終端中找到地址,復制并粘貼至新的瀏覽器頁面的地址欄,會發現同樣能夠進入剛才關閉的頁面。

因此,想要徹底退出Jupyter Notebook,需要關閉它的服務器。只需要在它啟動的終端上按:

  • Mac用戶:control c
  • Windows用戶:ctrl c

然后在終端上會提示:“Shutdown this notebook server (y/[n])?”輸入y即可關閉服務器,這才是徹底退出了Jupyter Notebook程序。此時,如果你想要通過輸入剛才關閉網頁的網址進行訪問Jupyter Notebook便會看到報錯頁面。

九、參考資料

1.知乎:jupyter notebook 可以做哪些事情?猴子的回答

  1. Jupyter Notebook官方介紹

  2. Anaconda官方下載頁面

  3. Python·Jupyter Notebook各種使用方法記錄

  4. Stack Overflow中有關如何隱藏/顯示輸入單元格的問題

  5. 魔術命令官方文檔

  6. Jupyter Notebook 的快捷鍵

  7. Jupyter Notebook官方文檔

?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,786評論 6 534
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,656評論 3 419
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,697評論 0 379
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,098評論 1 314
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,855評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,254評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,322評論 3 442
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,473評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,014評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,833評論 3 355
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,016評論 1 371
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,568評論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,273評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,680評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,946評論 1 288
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,730評論 3 393
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,006評論 2 374

推薦閱讀更多精彩內容