Jupyter - Szybki przewodnik

Projekt Jupyter to pakiet oprogramowania używanego w komputerach interaktywnych. IPython został pierwotnie opracowany przez Fernando Pereza w 2001 roku jako ulepszony interpreter Pythona. Internetowy interfejs do terminala IPython w postaci notatnika IPython został wprowadzony w 2011 roku. W 2014 roku Projekt Jupyter rozpoczął się jako projekt spin-off z IPython.

Pakiety w ramach projektu Jupyter obejmują -

  • Jupyter notebook - Interfejs sieciowy do środowisk programistycznych Python, Julia, R i wielu innych

  • QtConsole - Terminal oparty na Qt dla jąder Jupyter podobny do IPythona

  • nbviewer - Możliwość udostępniania notebooków Jupyter

  • JupyterLab - Nowoczesny zintegrowany interfejs sieciowy dla wszystkich produktów.

Standardowa dystrybucja Pythona zawiera rozszerzenie REPL (Read-Evaluate-Print Loop) środowisko w postaci powłoki Pythona z >>>skłonić. IPython (skrót od Interactive Python) to ulepszone interaktywne środowisko dla języka Python z wieloma funkcjami w porównaniu do standardowej powłoki Pythona.

Funkcje IPythona

IPython oferuje więcej funkcji w porównaniu do standardowego Pythona. Są następujące -

  • Oferuje potężną interaktywną powłokę Pythona.

  • Działa jako główne jądro dla notebooka Jupyter i innych narzędzi front-endowych Project Jupyter.

  • Posiada zdolność introspekcji obiektu. Introspekcja to możliwość sprawdzenia właściwości obiektu w czasie wykonywania.

  • Podświetlanie składni.

  • Przechowuje historię interakcji.

  • Uzupełnianie tabulatorami słów kluczowych, zmiennych i nazw funkcji.

  • Magiczny system poleceń przydatny do kontrolowania środowiska Python i wykonywania zadań systemu operacyjnego.

  • Możliwość osadzenia w innych programach w języku Python.

  • Zapewnia dostęp do debuggera języka Python.

Historia i rozwój

IPython został pierwotnie opracowany przez Fernando Pereza w 2001 roku. Jego aktualna wersja to IPython7.0.1, która wymaga Pythona 3.4 lub nowszego. IPython 6.0 był pierwszą wersją obsługującą Python 3. Użytkownicy korzystający z Pythona 2.7 powinni pracować z wersjami od 2.0 do 5.7 IPythona

Koncepcja notebooków obliczeniowych rozpoczęła się w dekadzie lat 80-tych, kiedy pojawiły się MATLAB i Mathematica. Te nakładki GUI do powłoki interaktywnej miały takie funkcje, jak formatowanie tekstu, dodawanie grafiki, tabel i dodawanie symboli matematycznych. Notatnik Sage to także notatnik internetowy.

Twórcy IPython rozpoczęli pracę nad interfejsem notebooka dla powłoki IPython w 2005 roku. Notebook IPython wkrótce dodał obsługę innych języków, takich jak R i Julia. To było w 2014 roku, kiedy Perez rozpoczął projekt Jupyter jako spin-off z IPython, ponieważ projekt IPython stał się duży dzięki takim produktom jak serwer notebooków i konsola Qt.

Od czasu IPython 4.0 wszystkie dodatkowe komponenty zostały przeniesione do Project Jupyter i dodano obsługę innych języków do notatnika IPython. IPython nadal koncentruje się na ulepszaniu swojej rozszerzonej funkcji interpretera. Zapewnia również podstawowe jądro dla nakładki na notebooka Jupyter.

IPython jest domyślnie dołączony do dystrybucji Anaconda Pythona. Można go pobrać ze strony pobierania Anaconda www.anaconda.com/download/. Pliki binarne dla wszystkich głównych systemów operacyjnych (Windows, MacOS i Linux) i architektury (32-bitowej i 64-bitowej) są dostępne pod tym linkiem.

Aby zainstalować IPython osobno w standardowej instalacji Pythona, możesz użyć polecenia pip, jak pokazano poniżej -

pip3 install ipython

IPython wewnętrznie używa następujących pakietów -

Sr.No. Zależności i funkcje IPythona
1

colorama

Wieloplatformowy interfejs API do drukowania kolorowego tekstu terminala z Pythona

2

jedi

Narzędzie do autouzupełniania dla Pythona

3

pickleshare

Mała „półka”, taka jak magazyn danych z obsługą współbieżności

4

prompt_toolkit

Biblioteka do tworzenia potężnych interaktywnych linii poleceń w Pythonie

5

pygments

Pakiet podświetlania składni napisany w Pythonie

6

simplegeneric

Proste funkcje ogólne

7

traitlets

System konfiguracji aplikacji Python.

Ogólnie wszystkie zależności są instalowane automatycznie. W przeciwnym razie możesz zainstalować je indywidualnie za pomocą pip.

W tym rozdziale wyjaśniono, jak rozpocząć pracę z IPythonem.

Uruchamianie IPythona z wiersza polecenia.

Zanim przejdziemy do szczegółowego zrozumienia IPythona, zwróć uwagę, że zamiast zwykłego >>>, zauważysz dwa główne monity Pythona, jak wyjaśniono poniżej -

  • In[1] pojawia się przed jakimkolwiek wyrażeniem wejściowym.

  • Out[1] pojawia się przed wyświetleniem Wyjście.

Poza tym liczby w nawiasach kwadratowych są zwiększane automatycznie. Obserwuj poniższy zrzut ekranu, aby lepiej zrozumieć -

Teraz, jeśli zainstalowałeś dystrybucję Pythona Anaconda, otwórz monit Anaconda z menu Start.

Uruchom IPythona z wiersza polecenia Conda

W porównaniu do zwykłej konsoli Pythona możemy zauważyć różnicę. Powłoka IPythona wyświetla podświetlanie składni przy użyciu różnych schematów kolorów dla różnych elementów, takich jak wyrażenie, funkcja, zmienna itp.

Kolejnym przydatnym ulepszeniem jest uzupełnianie zakładek. Wiemy, że każdy obiekt ma jedną lub więcej dostępnych metod zdefiniowanych w jego klasie. IPython wyświetla odpowiednią listę metod po naciśnięciu klawisza tabulatora po kropce przed obiektem.

W poniższym przykładzie zdefiniowano ciąg. W odpowiedzi pokazane są metody klasy string.

IPython dostarcza informacji o każdym obiekcie poprzez wstawienie „?” Przed tym. Zawiera ciąg dokumentów, definicje funkcji i szczegóły konstruktora klasy. Na przykład, aby zbadać zdefiniowany powyżej obiekt łańcuchowy var, w polu wprowadzania wprowadźvar?. Wynik pokaże wszystkie informacje na ten temat. Aby lepiej zrozumieć, spójrz na poniższy zrzut ekranu -

Funkcje magiczne

Wbudowane magiczne funkcje IPythona są niezwykle potężne. Istnieją dwa rodzaje funkcji magicznych.

  • Line magics, które działają bardzo podobnie do poleceń DOS.
  • Cell magics, które działają na wielu wierszach kodu.

O magicznych funkcjach linii i magicznych funkcjach komórki dowiemy się szczegółowo w kolejnych rozdziałach.

W tym rozdziale wyjaśnimy, jak uruchomić i edytować skrypt w języku Python.

Uruchom polecenie

Możesz użyć runpolecenie w wierszu polecenia, aby uruchomić skrypt w języku Python. Polecenie run jest w rzeczywistości magicznym poleceniem linii i powinno być zapisane jako%run. Jednakże%automagic Tryb jest zawsze domyślnie włączony, więc możesz to pominąć.

In [1]: run hello.py
Hello IPython

Edytuj polecenie

IPython udostępnia również polecenie edit magic. Wywołuje domyślny edytor systemu operacyjnego. Możesz go otworzyć za pomocą edytora Notatnika Windows, a skrypt można edytować. Gdy zamkniesz go po zapisaniu jego wejścia, zostanie wyświetlone wyjście zmodyfikowanego skryptu.

In [2]: edit hello.py
Editing... done. Executing edited code...
Hello IPython
welcome to interactive computing

Zauważ, że hello.py początkowo zawierał tylko jedną instrukcję, a po edycji została dodana jeszcze jedna instrukcja. Jeśli nie podano nazwy pliku do polecenia edycji, tworzony jest plik tymczasowy. Obserwuj następujący kod, który pokazuje to samo.

In [7]: edit
IPython will make a temporary file named:
C:\Users\acer\AppData\Local\Temp\ipython_edit_4aa4vx8f\ipython_edit_t7i6s_er.py
Editing... done. Executing edited code...
magic of IPython
Out[7]: 'print ("magic of IPython")'

IPython zachowuje zarówno polecenia, jak i ich wyniki z bieżącej sesji. Możemy przewijać poprzednie polecenia, naciskając klawisze w górę iw dół.

Poza tym ostatnie trzy obiekty wyniku są przechowywane w specjalnych zmiennych _, __ i ___. Plikhistory magiczne polecenie pokazuje poprzednie polecenia w bieżącej sesji, jak pokazano na zrzucie ekranu podanym poniżej -

Jeśli instrukcja w komórce wejściowej zaczyna się od symbolu wykrzyknika (!), Jest traktowana jako polecenie systemowe dla bazowego systemu operacyjnego. Na przykład,!ls (dla systemu Linux) i !dir (dla Windows) wyświetla zawartość bieżącego katalogu

Dane wyjściowe polecenia systemowego można również przypisać do zmiennej Pythona, jak pokazano poniżej -

Zmienna przechowuje dane wyjściowe bez kolorów i podziałów w znakach nowej linii.

Możliwe jest również łączenie zmiennych lub wyrażeń Pythona z wywołaniami poleceń systemowych. Zmienna w nawiasach klamrowych {} może być osadzona w tekście polecenia. Zwróć uwagę na następujący przykład -

Oto kolejny przykład, aby zrozumieć, że poprzedzanie zmiennej Pythona znakiem $ również daje ten sam wynik.

W tym rozdziale wyjaśnimy, jak pracować z różnymi opcjami wiersza poleceń w IPythonie.

Wywołanie programu IPython

Możesz wywołać program IPython, korzystając z następujących opcji -

C:\python36> ipython [subcommand] [options] [-c cmd | -m mod | file] [--] [arg]

Opcja pliku to skrypt w Pythonie z rozszerzeniem .py. Jeśli nie podano innej opcji, skrypt jest wykonywany, a wiersz poleceń pojawia się ponownie.

C:\python36>ipython hello.py
Hello IPython
welcome to interactive computing

Polecenia i parametry

Polecenie IPython akceptuje następujące opcje podkomendy -

  • Profile - Twórz i zarządzaj profilami IPython.

  • Kernel - Uruchom jądro bez dołączonej nakładki.

  • Locate - Wydrukuj ścieżkę do katalogu IPython.

  • History - Zarządzaj bazą danych historii IPython.

Podkomenda profilu IPython akceptuje następujące parametry -

  • ipython profile create myprofile - Tworzy nowy profil.

  • ipython profile list - Wyświetla wszystkie dostępne profile.

  • ipython locate profile myprofile - Lokalizuje wymagany profil.

Aby zainstalować nowe jądro IPython, użyj następującego polecenia -

Ipython kernel –install –name

Aby wydrukować ścieżkę do katalogu IPython, użyj następującego polecenia -

C:\python36>ipython locate myprofile
C:\Users\acer\.ipython

Poza tym wiemy, że -

  • Plik history podkomenda zarządza bazą danych historii IPythona.

  • Plik trim opcja redukuje bazę danych historii IPython do ostatnich 1000 wpisów.

  • Plik clear opcja usuwa wszystkie wpisy.

Niektóre inne ważne opcje wiersza poleceń IPythona są wymienione poniżej -

Sr.No. Polecenie i opis IPythona
1

--automagic

Włącz automatyczne wywoływanie magicznych poleceń.

2

--pdb

Włącz automatyczne wywoływanie debugera pdb po każdym wyjątku.

3

--pylab

Wczytaj wstępnie matplotlib i numpy do interaktywnego użytku z domyślnym zapleczem matplotlib.

4

--matplotlib

Skonfiguruj matplotlib do użytku interaktywnego z domyślnym zapleczem matplotlib.

5

--gui=options

Włącz integrację pętli zdarzeń GUI z dowolnymi z („glut”, „gtk”, „gtk2”, „gtk3”, „osx”, „pyglet”, „qt”, „qt4”, „qt5”, „tk”, „ wx ',' gtk2 ',' qt4 ').

Przykładowe użycie niektórych opcji wiersza poleceń IPython przedstawiono w poniższej tabeli -

Sr.No. Polecenie i opis IPythona
1

ipython --matplotlib

włącz integrację matplotlib

2

ipython --matplotlib=qt

włącz integrację matplotlib z zapleczem qt4

3

ipython --profile=myprofile

zacznij od profilu foo

4

ipython profile create myprofile

stwórz foo profilu z domyślnymi plikami konfiguracyjnymi

5

ipython help profile

pokaż pomoc dla profilu subcmd

6

ipython locate

wypisuje ścieżkę do katalogu IPython

7

ipython locate profile myprofile

wypisuje ścieżkę do katalogu dla profilu „myprofile”

IPython ma różne sposoby dynamicznego uzyskiwania informacji o obiektach Pythona. W tym rozdziale poznajmy sposoby dynamicznej introspekcji obiektów w IPythonie.

Zastosowanie ? i ??zawiera konkretne i bardziej szczegółowe informacje o obiekcie. W pierwszym przykładzie omówionym poniżej tworzony jest prosty obiekt będący liczbą całkowitą a. Jego informacje można uzyskać, wpisując? w komórce wejściowej.

W drugim przykładzie zdefiniujmy funkcję i przyjrzyjmy się temu obiektowi funkcji za pomocą ? i ??.

Zwróć uwagę, że magiczna funkcja %psearch jest równoważne użyciu ? lub ?? do pobierania informacji o obiekcie.

Komórki wejściowe i wyjściowe w konsoli IPython są numerowane przyrostowo. W tym rozdziale przyjrzyjmy się szczegółowo buforowaniu IO w Pythonie.

W IPythonie dane wejściowe są pobierane za pomocą klawisza strzałki w górę. Poza tym wszystkie poprzednie dane wejściowe są zapisywane i można je odzyskać. Zmienne_i, __i, i ___izawsze przechowuj poprzednie trzy wpisy. Dodatkowo,In i _inzmienne zawiera listy wszystkich danych wejściowych. Oczywiście_in[n]pobiera dane wejściowe z n-tej komórki wejściowej. Poniższa sesja IPython pomoże ci zrozumieć to zjawisko -

In [1]: print ("Hello")
Hello

In [2]: 2+2
Out[2]: 4

In [3]: x = 10

In [4]: y = 2

In [5]: pow(x,y)
Out[5]: 100

In [6]: _iii, _ii, _i
Out[6]: ('x = 10', 'y = 2', 'pow(x,y)')

In [7]: In
Out[7]:
['',
   'print ("Hello")',
   '2+2',
   'x = 10',
   'y = 2',
   'pow(x,y)',
   '_iii, _ii, _i',
   'In'
]
   
In [8]: In[5] 9. IPython — IO
Out[8]: 'pow(x,y)'

In [9]: _ih
Out[9]:
['',
   'print ("Hello")',
   '2+2',
   'x = 10',
   'y = 2',
   'pow(x,y)',
   '_iii, _ii, _i',
   'In',
   'In[5]',
   '_ih'
]
   
In [11]: _ih[4]
Out[11]: 'y = 2'

In [12]: In[1:4]
Out[12]: ['print ("Hello")', '2+2', 'x=10']

Podobnie pojedyncze, podwójne i potrójne podkreślenia działają jako zmienne do przechowywania poprzednich trzech wyników. RównieżOut i _ohtworzą obiekt słownikowy zawierający numer komórki i dane wyjściowe komórek wykonujących akcję (bez instrukcji przypisania). Aby pobrać zawartość określonej komórki wyjściowej, użyjOut[n] lub _oh[n]. Możesz również użyć wycinania, aby uzyskać komórki wyjściowe w określonym zakresie.

In [1]: print ("Hello")
Hello

In [2]: 2+2
Out[2]: 4

In [3]: x = 10

In [4]: y = 3

In [5]: pow(x,y)
Out[5]: 1000

In [6]: ___, __, _
Out[6]: ('', 4, 1000)

In [7]: Out
Out[7]: {2: 4, 5: 1000, 6: ('', 4, 1000)}

In [8]: _oh
Out[8]: {2: 4, 5: 1000, 6: ('', 4, 1000)}

In [9]: _5
Out[9]: 1000

In [10]: Out[6]
Out[10]: ('', 4, 1000)

Różne zmienne środowiskowe wpływają na zachowanie Pythona. Zmienna środowiskowa PYTHONSTARTUP jest przypisana do skryptu w języku Python. W efekcie ten skrypt jest wykonywany przed pojawieniem się zachęty Pythona. Jest to przydatne, jeśli niektóre moduły mają być ładowane domyślnie przy każdym uruchomieniu nowej sesji Pythona.

Poniższy skrypt (start.py) importuje moduł IPython i wykonuje funkcję start_ipython () w celu zastąpienia domyślnej powłoki Pythona znakiem zachęty (>>>) przez powłokę IPython, gdy wywoływany jest plik wykonywalny Pythona.

import os, IPython
os.environ['PYTHONSTARTUP'] = ''
IPython.start_ipython()
raise SystemExit

Zakładając, że ten plik jest przechowywany w katalogu instalacyjnym Pythona (c: \ python36), ustaw zmienną środowiskową PYTHONSTARTUP i uruchom Pythona z wiersza poleceń. Następnie pojawi się powłoka IPythona, jak pokazano poniżej -

Należy pamiętać, że zmienną środowiskową można ustawić na stałe w oknie dialogowym Właściwości systemu w systemie Windows i za pomocą polecenia eksportu w systemie Linux.

IPython może czytać ze standardowej konsoli Pythona z domyślnymi ustawieniami >>>zachęta i kolejna sesja IPython. Poniższy zrzut ekranu przedstawia pętlę for napisaną w standardowej powłoce Pythona -

Skopiuj kod (wraz z podpowiedzią Pythona) i wklej go w komórce wejściowej IPython. IPython inteligentnie odfiltrowuje podpowiedzi wejściowe (>>> i ...) lub podpowiedzi IPythona (w [N]: i ... :)

Podobnie, kod z jednej sesji IPython można wkleić do innej. Pierwszy zrzut ekranu pokazany poniżej przedstawia definicję funkcji SayHello () w jednym oknie IPythona -

Teraz wybierzmy kod i wklejmy go do innej powłoki IPythona i wywołajmy funkcję SayHello ().

Funkcja embed () modułu IPython umożliwia osadzenie IPythona w przestrzeni nazw kodów Pythona. W ten sposób możesz wykorzystać funkcje IPythona, takie jak introspekcja obiektów i uzupełnianie kart, w domyślnym środowisku Python.

Obiekty Pythona obecne w globalnej przestrzeni nazw przed osadzeniem będą dostępne dla IPythona.

Jeśli nowe obiekty zostaną utworzone w IPythonie lub poprzednie obiekty zostaną zmodyfikowane, będą one automatycznie dostępne w domyślnym środowisku po wyjściu z IPython. Osadzona powłoka IPython nie zmienia stanu wcześniejszego kodu ani obiektów.

Jeśli jednak IPython jest osadzony w lokalnej przestrzeni nazw, tak jak wewnątrz funkcji, obiekty w nim zawarte nie będą dostępne po zamknięciu. Tutaj zdefiniowaliśmy funkcję add (). Wewnątrz add () wywołujemy IPython i deklarujemy zmienną. Jeśli spróbujemy uzyskać dostęp do zmiennej w IPythonie po jej zamknięciu, zostanie zgłoszony wyjątek NameError.

Magiczne polecenia lub magiczne funkcje to jedne z ważnych ulepszeń oferowanych przez IPython w porównaniu ze standardową powłoką Pythona. Te magiczne polecenia mają na celu rozwiązanie typowych problemów w analizie danych za pomocą Pythona. W rzeczywistości kontrolują zachowanie samego IPythona.

Magiczne polecenia działają jak wygodne funkcje, w których składnia Pythona nie jest najbardziej naturalna. Są przydatne do osadzania nieprawidłowej składni Pythona w ich przepływie pracy.

Rodzaje magicznych poleceń

Istnieją dwa rodzaje magicznych poleceń -

  • Magia liniowa
  • Magia komórkowa

Line Magics

Są podobne do wywołań wiersza poleceń. Zaczynają się od znaku%. Reszta wiersza to argument przekazany bez nawiasów i cudzysłowów. Magii liniowej można używać jako wyrażenia, a ich wartość zwracaną można przypisać do zmiennej.

Cell Magics

Mają prefiks znaków %%. W przeciwieństwie do magicznych funkcji linii, mogą działać na wielu liniach poniżej ich wywołania. W rzeczywistości mogą wprowadzać dowolne modyfikacje otrzymywanych danych wejściowych, które wcale nie muszą być prawidłowym kodem Pythona. Otrzymują cały blok jako pojedynczy ciąg.

Aby dowiedzieć się więcej o funkcjach magicznych, wbudowanej magii i ich dokumentach, użyj magicznego polecenia. Informacje o określonej funkcji magicznej uzyskuje się przez%magicfunction?Komenda. Opiszmy teraz niektóre z wbudowanych magicznych poleceń linii i komórek.

Wbudowana magia liniowa

%autocall [mode]

Ta magiczna funkcja umożliwia automatyczne wywołanie funkcji bez konieczności używania nawiasów. Przyjmuje trzy możliwe parametry trybu:0 (off), 1 (smart) is default lub 2 (always on).

% automagic

Magiczne funkcje są wywoływalne bez konieczności wpisywania początkowego%, jeśli jest ustawiona na 1. Bez argumentów włącza / wyłącza. Aby dezaktywować, ustaw na 0.

Poniższy przykład przedstawia magiczną funkcję %pwd (wyświetla bieżący katalog roboczy) jest wywoływana bez początku%, gdy% automagic jest ustawione na 1

%Płyta CD

Ta magia linii zmienia bieżący katalog. To polecenie automatycznie utrzymuje wewnętrzną listę katalogów odwiedzanych podczas sesji IPython, w zmiennej _dh. Możesz także użyć polecenia „cd - <tab>”, aby wygodnie wyświetlić historię katalogów.

Stosowanie

Polecenie% cd może być używane na następujące sposoby -

  • %cd <dir> - Zmienia bieżący katalog roboczy na <dir>

  • %cd.. - Zmienia bieżący katalog na katalog nadrzędny

  • %cd - zmiany w ostatnio odwiedzanym katalogu.

% dhist

To magiczne polecenie wyświetla wszystkie katalogi, które odwiedziłeś w bieżącej sesji. Za każdym razem, gdy używane jest polecenie% cd, ta lista jest aktualizowana w_dh zmienna.

%edytować

To magiczne polecenie wywołuje domyślny edytor tekstu obecnego systemu operacyjnego (Notatnik dla Windows) do edycji skryptu Pythona. Skrypt jest wykonywany po zamknięciu edytora.

% env

To magiczne polecenie wyświetli wszystkie zmienne środowiskowe. Odczytuje również wartość określonej zmiennej lub ustawia wartość zmiennej środowiskowej.

Usage

Polecenie% cd może być używane na następujące sposoby -

  • %env - Wyświetla wszystkie zmienne środowiskowe

  • %env var - Pobiera wartość dla var

  • %env var val - Ustawia wartość dla var

% gui [GUINAME]

W przypadku użycia bez argumentów polecenie to włącza lub wyłącza integrację pętli zdarzeń interfejsu GUI IPython. Z argumentem GUINAME, ta magia zastępuje domyślne zestawy narzędzi GUI określonym.

Sr.No. Polecenie i opis
1

%gui wx

włącz integrację pętli zdarzeń wxPython

2

%gui qt4|qt

włącz integrację pętli zdarzeń PyQt4

3

%gui qt5

włącz integrację pętli zdarzeń PyQt5

4

%gui gtk

włącz integrację pętli zdarzeń PyGTK

5

%gui gtk3

włącz integrację pętli zdarzeń Gtk3

6

%gui tk

włącz integrację pętli zdarzeń Tk

7

%gui osx

włącz integrację pętli zdarzeń Cocoa

8

(wymaga% matplotlib 1.1)

9

%gui

wyłącz integrację wszystkich pętli zdarzeń

% lsmagic

Wyświetla wszystkie aktualnie dostępne magiczne funkcje

% matplotlib

Ta funkcja aktywuje interaktywną obsługę matplotlib podczas sesji IPython. Jednak nie importuje biblioteki matplotlib. Domyślny zestaw narzędzi GUI matplotlib to TkAgg. Ale możesz jawnie zażądać innego zaplecza GUI. Możesz zobaczyć listę dostępnych backendów, jak pokazano -

In [4]: %matplotlib --list
Available matplotlib backends: 
['osx', 'qt4', 'qt5', 'gtk3', 'notebook', 'wx', 'qt', 'nbagg','gtk', 'tk', 'inline']

Sesja IPythona pokazana tutaj wykreśla sinusoidę za pomocą qt zestaw narzędzi -

Podczas korzystania z notatnika Jupyter dyrektywa% matplotlib inline wyświetla dane wyjściowe tylko w przeglądarce.

%notatnik

Ta funkcja konwertuje bieżącą historię IPython do pliku notatnika IPython z rozszerzeniem ipynb. Komórki wejściowe z poprzedniego przykładu są zapisywane jako sine.ipynb

%notebook sine.ipynb

% pinfo

Ta funkcja jest podobna do introspekcji obiektu? postać. Aby uzyskać informacje o obiekcie, użyj następującego polecenia -

%pinfo object

To jest synonimem object? lub ?object.

%precyzja

Ta magiczna funkcja ogranicza wynik zmiennoprzecinkowy do określonych cyfr po przecinku.

% pwd

Ta magiczna funkcja zwraca aktualny katalog roboczy.

% pylab

Ta funkcja wypełnia bieżącą sesję IPythona bibliotekami matplotlib i numpy.

%odwołanie

Wykonana bez żadnego parametru, ta funkcja wykonuje poprzednie polecenie.

Zauważ, że w %recall n, numer przed nim to numer komórki wejściowej. Stąd przywoływane jest polecenie w n-tej komórce. Możesz przywołać polecenia w sekcji komórek za pomocą polecenia, takiego jak%recall 1-4. Bieżąca komórka wejściowa jest wypełniona wywołaną komórką, a kursor miga do momentu naciśnięcia klawisza Enter.

%biegać

To polecenie uruchamia skrypt Pythona z poziomu powłoki IPython.

%czas

To polecenie wyświetla czas wymagany przez środowisko IPython do wykonania wyrażenia w języku Python.

% timeit

Ta funkcja wyświetla również czas wymagany przez środowisko IPython do wykonania wyrażenia Python. Wykonywanie instrukcji lub wyrażeń w Pythonie w czasie korzysta z modułu timeit. Ta funkcja może być używana zarówno jako magia linii, jak i komórki, jak wyjaśniono tutaj -

  • W line mode możesz mierzyć czas w jednej linii.

  • W cell mode, instrukcja w pierwszym wierszu jest używana jako kod konfiguracji, a czas trwania treści komórki jest określany. Ciało komórki ma dostęp do wszystkich zmiennych utworzonych w kodzie konfiguracji.

%WHO

Ta magia linii wypisuje wszystkie interaktywne zmienne, z minimalnym formatowaniem. Jeśli podano jakiekolwiek argumenty, wypisywane są tylko zmienne, których typ pasuje do jednego z nich.

Funkcja IPython Custom Line Magic

Podstawowa biblioteka IPythona zawiera dekorator register_line_magic. Funkcja zdefiniowana przez użytkownika jest przekształcana w magiczną funkcję liniową przy użyciu tego dekoratora.

Projekt Jupyter rozpoczął się jako spin-off z projektu IPython w 2014 roku. Właściwości językowe IPythona zostały przeniesione pod nazwą - Jupyter. Nazwa jest odniesieniem do podstawowych języków programowania obsługiwanych przez Jupyter, którymi są Julia, Python i RProdukty w ramach projektu Jupyter, które mają wspierać interaktywną naukę o danych i obliczenia naukowe.

Projekt Jupyter składa się z różnych produktów opisanych jako -

  • IPykernel - To jest pakiet dostarczający jądro IPython do Jupyter.

  • Jupyter client- Ten pakiet zawiera referencyjną implementację protokołu Jupyter. Jest to również biblioteka kliencka do uruchamiania, zarządzania i komunikacji z jądrami Jupyter.

  • Jupyter notebook- To był wcześniej znany jako notatnik IPython. Jest to interfejs sieciowy do jądra IPython i jąder wielu innych języków programowania.

  • Jupyter kernels - Kernel to środowisko wykonawcze języka programowania dla produktów Jupyter.

Lista jąder Jupyter znajduje się poniżej -

Jądro Język URL
IJulia Julia

https://github.com/JuliaLang

IHaskell Haskell

https://github.com/gibiansky

IRuby Rubin

https://github.com/SciRuby/iruby

IJavaScript JavaScript

https://github.com/n-riesco

IPHP PHP

https://github.com/dawehner

IRKernel R

http://irkernel.github.io/

  • Qtconsole - Bogata konsola oparta na Qt do pracy z jądrem Jupyter

  • nbconvert - Konwertuje pliki notatników Jupyter w innych formatach

  • JupyterLab - Zintegrowany interfejs sieciowy dla notebooków, edytorów, konsol itp.

  • nbviewer - Przeglądarka HTML do plików notebooków

Notatnik IPython został opracowany przez Fernando Pereza jako interfejs sieciowy do jądra IPython. W celu stworzenia zintegrowanego, interaktywnego środowiska obliczeniowego dla wielu języków, projekt Notebook został przeniesiony do projektu Jupyter, zapewniając interfejs dla środowisk programistycznych Juila i R oprócz Pythona.

Dokument notatnika składa się z elementów sformatowanego tekstu z tekstem w formacie HTML, rysunkami, równaniami matematycznymi itp. Notatnik jest również plikiem wykonywalnym składającym się z bloków kodu w języku Python lub innych pomocniczych językach.

Notatnik Jupyter to aplikacja typu klient-serwer. Aplikacja uruchamia serwer na komputerze lokalnym i otwiera interfejs notebooka w przeglądarce internetowej, gdzie można ją edytować i uruchamiać. Notatnik jest zapisywany jako plik ipynb i można go eksportować jako pliki html, pdf i LaTex.

Jeśli jesteś nowy w Jupyter, możesz wypróbować funkcje notebooka Jupyter przed zainstalowaniem go na komputerze lokalnym. W tym celu odwiedźhttps://jupyter.org w przeglądarce i wybierz ‘Try Jupyter with Python’ opcja.

Otworzy się strona główna programu https://mybinder.orgZ menu Plik wybierz opcję nowego notatnika, aby otworzyć pusty Jupyter w przeglądarce. Zostanie wyświetlona komórka wejściowa, podobnie jak w terminalu IPython. Możesz wykonać w nim dowolne wyrażenie Pythona.

Możesz łatwo zainstalować aplikację notebooka Jupyter za pomocą menedżera pakietów pip.

pip3 install jupyter

Aby uruchomić aplikację, użyj następującego polecenia w oknie wiersza polecenia.

c:\python36>jupyter notebook

Aplikacja serwera zostanie uruchomiona na domyślnym porcie o numerze 8888 i otworzy się okno przeglądarki, aby wyświetlić pulpit nawigacyjny notebooka.

Zwróć uwagę, że pulpit nawigacyjny pokazuje listę rozwijaną w pobliżu prawej krawędzi przeglądarki ze strzałką obok przycisku Nowy. Zawiera aktualnie dostępne jądra notebooków. Teraz wybierz Python 3, a następnie nowy notatnik zostanie otwarty w nowej karcie. Wyświetlana jest komórka wejściowa podobna do komórki w konsoli IPython.

Możesz wykonać w nim dowolne wyrażenie Pythona. Wynik zostanie wyświetlony w komórce Out.

Pulpit nawigacyjny Jupyter Notebook zawiera trzy zakładki, jak pokazano na zrzucie ekranu podanym poniżej -

Karta Pliki

Zakładka „Pliki” wyświetla pliki i foldery w bieżącym katalogu, z którego została wywołana aplikacja notebooka. Wiersz odpowiadający aktualnie otwartemu notatnikowi i statusowi pracy jest wyświetlany tuż obok ostatniej zmodyfikowanej kolumny. Wyświetla również przycisk Prześlij, za pomocą którego można przesłać plik na serwer notebooka.

Zakładka Running

Karta „Uruchomione” pokazuje, które z notebooków są aktualnie uruchomione.

Zakładka Cluster

Trzecia zakładka, „Klastry”, jest udostępniana przez równoległy protokół IPython. Platforma przetwarzania równoległego IPython, rozszerzona wersja jądra IPython.

Z rozwijanego menu Nowy wybierz Terminal, aby otworzyć okno cmd. Możesz teraz uruchomić terminal IPython tutaj.

W interfejsie użytkownika Jupyter, tuż obok logo w nagłówku, wyświetlana jest nazwa pliku.

Możesz znaleźć pasek menu pod nagłówkiem. Każde menu zawiera wiele opcji, które zostaną omówione później.

Rząd ikon tworzących pasek narzędzi pomaga użytkownikowi w wykonywaniu często wymaganych operacji

Notebook ma dwa tryby - Command mode i Edit mode. Notatnik przechodzi w tryb edycji po kliknięciu komórki. Zwróć uwagę na symbol ołówka obok nazwy jądra.

Symbol wskaźnika jądra jest wyświetlany po prawej stronie nazwy jądra. Zauważ, że puste kółko oznacza, że ​​jądro jest bezczynne, a wypełnione kółko oznacza, że ​​jest zajęte.

Menu plików

Poniżej przedstawiono opcje dostępne w menu Plik -

Sr.No. Menu pliku i opis
1

New notebook

wybierz jądro, aby rozpocząć nowy notatnik

2

Open

Przenosi użytkownika do pulpitu nawigacyjnego, aby wybrać notatnik do otwarcia

3

Save as

zapisz bieżący notatnik i uruchom nowe jądro

4

Rename

zmienić nazwę bieżącego notatnika

5

Save

zapisuje aktualny notatnik i przechowuje aktualny punkt kontrolny

6

Revert

przywraca stan notebooka do wcześniejszego punktu kontrolnego

7

Download

wyeksportuj notatnik w jednym z różnych formatów plików

Dostępne formaty plików przedstawiono poniżej -

Menu Edytuj

Menu edycji składa się z przycisków służących do wycinania, kopiowania i wklejania komórek, usuwania wybranych komórek, dzielenia i scalania komórek, przenoszenia komórek w górę iw dół, wyszukiwania i zastępowania w notatniku, wycinania / kopiowania załączników i wstawiania obrazu.

Zobacz menu

Przyciski w tym menu pomagają nam ukryć / wyświetlić nagłówek, pasek narzędzi i numery komórek.

Wstaw menu

To menu zawiera opcje wstawiania komórki przed lub po bieżącej komórce.

Menu komórki

Opcje w tym menu pozwalają użytkownikowi uruchomić wszystkie lub określone komórki w notatniku. Możesz także ustawić typ komórki na typ kodu, przecenę lub surowy typ konwersji nb.

Menu jądra

Z tego menu możesz uruchomić, przerwać, zrestartować lub zamknąć jądro. Możesz także rozpocząć nowe jądro.

Menu widżetów

Z tego menu można zapisywać, usuwać, pobierać lub osadzać stan widżetów.

Menu pomocy

W tym menu wyświetlane są różne predefiniowane skróty klawiaturowe. Możesz także edytować skróty według własnego uznania.

Komórki w notatniku Jupyter są trzech typów - Code, Markdown i Raw.

Komórki kodu

Zawartość tej komórki jest traktowana jako instrukcje w języku programowania bieżącego jądra. Domyślnym jądrem jest Python. Tak więc możemy pisać instrukcje Pythona w komórce kodu. Po uruchomieniu takiej komórki jej wynik jest wyświetlany w komórce wyjściowej. Dane wyjściowe mogą być tekstem, obrazem, wykresami matplotlib lub tabelami HTML. Komórki kodu mają funkcję tekstu sformatowanego.

Markdown Cells

Te komórki zawierają tekst sformatowany przy użyciu języka znaczników. Dostępne są wszystkie rodzaje funkcji formatowania, takie jak pogrubianie tekstu i kursywa, wyświetlanie uporządkowanej lub nieuporządkowanej listy, renderowanie zawartości tabelarycznej itp. Komórki Markdown są szczególnie przydatne w celu zapewnienia dokumentacji procesu obliczeniowego notatnika.

Surowe komórki

Zawartość surowych komórek nie jest oceniana przez jądro notebooka. Po przejściu przez nbconvert będą renderowane zgodnie z oczekiwaniami. Jeśli wpiszesz LatEx w nieprzetworzonej komórce, renderowanie nastąpi po zastosowaniu nbconvert.

Podczas gdy pasek menu i pasek narzędzi umożliwiają wykonywanie różnych operacji na notebooku, pożądane jest, aby móc używać skrótów klawiaturowych, aby wykonywać je szybko.

Notebooki Jupyter mają dwa różne tryby wprowadzania klawiatury -

  • Command Mode- Wiąże klawiaturę z działaniami na poziomie notebooka. Wskazywane przez szare obramowanie komórki z niebieskim lewym marginesem.

  • Edit Mode- Kiedy piszesz w komórce. Wskazuje zielona ramka komórki.

Tryb poleceń (naciśnij klawisz Esc, aby włączyć)

F

Znajdź i zamień

1

zmień komórkę na nagłówek 1

Ctrl-Shift-F

otwórz paletę poleceń

2

zmień komórkę na nagłówek 2

Ctrl-Shift-P

otwórz paletę poleceń

3

zmień komórkę na nagłówek 3

Enter

wejść w tryb edycji

4

zmień komórkę na nagłówek 4

P

otwórz paletę poleceń

5

zmień komórkę na nagłówek 5

Shift-Enter

uruchom komórkę, wybierz poniżej

6

zmień komórkę na nagłówek 6

Ctrl-Enter

uruchom wybrane komórki

A

wstaw komórkę powyżej

Alt-Enter

uruchom komórkę i wstaw poniżej

B

wstaw komórkę poniżej

Y

zmień komórkę na kod

X

wyciąć wybrane komórki

M

zmień komórkę na przecenę

C

skopiuj wybrane komórki

R

zmień komórkę na surową

V

wklej komórki poniżej

K

wybierz komórkę powyżej

Z

cofnąć usunięcie komórki

Up

wybierz komórkę powyżej

D,D

usuń wybrane komórki

Down

wybierz komórkę poniżej

Shift-M

scal zaznaczone komórki lub bieżącą komórkę z komórką poniżej, jeśli wybrano tylko jedną komórkę

J

wybierz komórkę poniżej

Shift-V

wklej komórki powyżej

Shift-K

rozszerz zaznaczone komórki powyżej

L

przełącz numery linii

Shift-Up

rozszerz zaznaczone komórki powyżej

O

przełączanie wyjścia wybranych komórek

Shift-Down

rozszerz wybrane komórki poniżej

Shift-O

przełącza przewijanie danych wyjściowych wybranych komórek

Shift-J

rozszerz wybrane komórki poniżej

I,I

przerwać jądro

Ctrl-S

Zapisz i Checkpoint

0,0

zrestartuj jądro (z oknem dialogowym)

S

Zapisz i Checkpoint

Esc

zamknij pager

Shift-L

przełącza numery wierszy we wszystkich komórkach i zachowuje ustawienie

Q

zamknij pager

Shift-Space

przewiń notatnik do góry

Space

przewiń notatnik w dół

Tryb edycji (naciśnij Enter, aby włączyć)

Tab

uzupełnienie kodu lub wcięcie

Ctrl-Home

idź do komórki początek

Shift-Tab

podpowiedź

Ctrl-Up

idź do komórki początek

Ctrl-]

akapit

Ctrl-End

idź na koniec komórki

Ctrl-[

oddany

Ctrl-Down

idź na koniec komórki

Ctrl-A

Zaznacz wszystko

Ctrl-Left

jedno słowo w lewo

Ctrl-Z

Cofnij

Ctrl-Right

jedno słowo dobrze

Ctrl-/

komentarz

Ctrl-M

wejść w tryb poleceń

Ctrl-D

usuń całą linię

Ctrl-Shift-F

otwórz paletę poleceń

Ctrl-U

cofnij wybór

Ctrl-Shift-P

otwórz paletę poleceń

Insert

przełącz flagę nadpisywania

Esc

wejść w tryb poleceń

Ctrl-Backspace

usuń słowo przed

Ctrl-Y

przerobić

Ctrl-Delete

usuń słowo po

Alt-U

ponów wybór

Shift-Enter

uruchom komórkę, wybierz poniżej

Ctrl-Shift-Minus

podziel komórkę pod kursorem

Ctrl-Enter

uruchom wybrane komórki

Down

przesuń kursor w dół

Alt-Enter

uruchom komórkę i wstaw poniżej

Up

przesuń kursor w górę

Ctrl-S

Zapisz i Checkpoint

Komórka Markdown wyświetla tekst, który można sformatować za pomocą języka znaczników. Aby wprowadzić tekst, który nie powinien być traktowany jako kod przez serwer Notatnika, należy go najpierw przekonwertować jako komórkę markdown albo z menu komórki albo za pomocą skrótu klawiaturowego M w trybie poleceń. Monit In [] przed zniknięciem komórki.

Komórka nagłówka

Komórka znaczników może wyświetlać tekst nagłówka w 6 rozmiarach, podobnie jak nagłówki HTML. Rozpocznij tekst w komórce markdown symbolem #. Użyj tylu symboli # odpowiadających poziomowi nagłówka, jaki chcesz. Oznacza to, że pojedynczy znak # będzie renderował największą linię nagłówka, a sześć symboli # renderuje nagłówek o najmniejszym rozmiarze czcionki. Renderowanie będzie miało miejsce po uruchomieniu komórki z menu komórki lub przycisku paska narzędzi.

Poniższy zrzut ekranu przedstawia komórki markdown w trybie edycji z nagłówkami na trzech różnych poziomach.

Gdy komórki są uruchomione, dane wyjściowe są następujące -

Zwróć uwagę, że przecena na notebooka Jupyter nie obsługuje funkcji WYSWYG. Efekt formatowania zostanie wyrenderowany dopiero po uruchomieniu komórki przeceny.

Listy uporządkowane

Aby wyświetlić listę numerowaną tak, jak to robi tag <ol> HTML, pierwsza pozycja na liście powinna mieć numer 1. Kolejne pozycje mogą mieć dowolną liczbę. Będzie renderowany seryjnie, gdy zostanie uruchomiona komórka przeceny. Aby wyświetlić listę z wcięciem, naciśnij klawisz tabulatora i zacznij pierwszą pozycję w każdej podlisty od 1.

Jeśli podasz następujące dane do obniżenia ceny -

Wyświetli następującą listę -

Listy punktowane

Każda pozycja na liście wyświetli pełne kółko, jeśli zaczyna się od symbolu -, gdzie jako wypełniony kwadrat będzie wyświetlany symbol, jeśli lista zaczyna się od symbolu *. Poniższy przykład wyjaśnia tę funkcję -

Wyrenderowany przecen pokazuje się jak poniżej -

Hiperłącza

Tekst Markdown zaczynający się od http lub https automatycznie renderuje hiperłącze. Aby dołączyć link do tekstu, umieść tekst w nawiasach kwadratowych [] i link w nawiasach (), opcjonalnie włączając tekst najechany kursorem. Poniższy zrzut ekranu wyjaśni to.

Wyrenderowany przecen pojawia się, jak pokazano poniżej -

Pogrubienie i kursywa

Aby wyświetlić tekst pogrubioną czcionką, umieść go między podwójnymi podkreśleniami lub dwiema gwiazdkami. Aby pokazać kursywą, umieść go między pojedynczymi podkreśleniami lub pojedynczymi gwiazdkami.

Wynik jest taki, jak pokazano poniżej -

Obrazy

Aby wyświetlić obraz w komórce znaczników, wybierz opcję „Wstaw obraz” z menu Edycja i przejdź do żądanego pliku obrazu. Komórka Markdown pokazuje swoją składnię w następujący sposób -

Obraz zostanie wyrenderowany na notebooku, jak pokazano poniżej -

Stół

W komórce przeceny tabelę można skonstruować za pomocą | (symbol potoku) i - (myślnik), aby zaznaczyć kolumny i wiersze. Zauważ, że symbole nie muszą być dokładnie wyrównane podczas pisania. Powinien zajmować tylko odpowiednie miejsce granic kolumn i wierszy. Notatnik automatycznie zmieni rozmiar w zależności od zawartości. Stół jest zbudowany tak, jak pokazano poniżej -

Tabela wyjściowa zostanie wyrenderowana, jak pokazano poniżej -

W tym rozdziale przyjrzyjmy się magicznym funkcjom komórek i ich funkcjom.

%% html

Ta magiczna funkcja komórki renderuje zawartość komórki kodu jako skrypt html.

%% js lub %% javascript

Możesz osadzić kod javascript w komórce notatnika Jupyter za pomocą tego magicznego polecenia komórki.

%% writefile

Zawartość komórki kodu jest zapisywana do pliku za pomocą tego polecenia.

Jądro IPython notebooka Jupyter jest w stanie wyświetlać wykresy kodu w komórkach wejściowych. Działa bezproblemowo zmatplotlibbiblioteka. Opcja inline z%matplotlib funkcja magiczna renderuje wykreśloną komórkę, nawet jeśli show()funkcja obiektu wykresu nie jest wywoływana. Plikshow() funkcja powoduje wyświetlenie figury poniżej w komórce [] bez wyjścia [] z numerem.

Teraz dodaj plt.show() na koniec i ponownie uruchom komórkę, aby zobaczyć różnicę.

Zauważ, że magia notatnika% matplotlib renderuje interaktywny wykres.

Tuż pod rysunkiem znajduje się pasek narzędzi do przełączania widoków, przesuwania, powiększania i pobierania opcji.

Co ważne, jeśli zmodyfikujesz dane pod wykresem, wyświetlanie zmienia się dynamicznie bez rysowania kolejnego wykresu.

W powyższym przykładzie zmień zestawy danych x i y w komórce poniżej i ponownie wykreśl rysunek, powyższy rysunek zostanie dynamicznie odświeżony.

Pliki notatników Jupyter mają .ipynbrozbudowa. Notatnik jest renderowany w przeglądarce internetowej przez aplikację notebooka. Można go wyeksportować do różnych formatów plików, korzystając z opcji pobierania w menu plików. Jupyter ma również interfejs wiersza poleceń w postacinbconvertopcja. Domyślnie nbconvert eksportuje notatnik do formatu HTML. W tym celu możesz użyć następującego polecenia -

jupyter nbconvert mynotebook.ipynb

To się nawróci mynotebook.ipynb do mynotebook.html. Inny format eksportu jest określony za pomocą`--to` klauzula.

Zwróć uwagę, że inne opcje to [„asciidoc”, „niestandardowe”, „html”, „latex”, „markdown”, „notebook”, „pdf”, „python”, „rst”, „script”, „slides”]

HTML zawiera szablony „podstawowe” i „pełne”. Możesz określić to w wierszu poleceń, jak pokazano poniżej -

jupyter nbconvert --to html --template basic mynotebook.ipynb

LaTex to format przygotowania dokumentów używany szczególnie w naukowym składzie. Jupyter zawiera szablony „bazy”, „artykułu” i „raportu”.

jupyter nbconvert --to latex –template report mynotebook.ipynb

Aby wygenerować plik PDF za pomocą lateksu, użyj następującego polecenia -

jupyter nbconvert mynotebook.ipynb --to pdf

Notatnik można wyeksportować do pokazu slajdów HTML. Konwersja wykorzystuje plik Reveal.js w tle. Aby udostępniać slajdy przez serwer HTTP, dodaj --postserve w wierszu poleceń. Aby tworzyć slajdy, które nie wymagają połączenia z Internetem, po prostu umieść bibliotekę Reveal.js w tym samym katalogu, w którymyour_talk.slides.html jest zlokalizowany.

jupyter nbconvert myslides.ipynb --to slides --post serve

Opcja przeceny przekształca notatnik w prosty wynik przeceny. Komórki Markdown pozostają niezmienione, a komórki kodu są wcięte 4 spacje.

--to markdown

Możesz użyć rstopcja konwersji notatnika do podstawowego wyjścia reStructuredText. Jest to przydatne jako punkt wyjścia do osadzania notatników w dokumentach Sphinx.

--to rst

To najprostszy sposób na pobranie skryptu Pythona (lub innego języka, w zależności od jądra) z notatnika.

--to script

IPyWidgets to biblioteka Pythona zawierająca interaktywne widżety HTML dla notatnika Jupyter. Każdy element interfejsu użytkownika w bibliotece może odpowiadać na zdarzenia i wywoływać określone funkcje obsługi zdarzeń. Wzmacniają interaktywną funkcję aplikacji notebooka Jupyter.

Aby włączyć widżety do notatnika, musimy zaimportować następujący moduł, jak pokazano poniżej -

from ipywidgets import widgets

Tutaj wyjaśniono niektóre podstawowe IPyWidgets -

Wprowadzanie tekstu

Plik widgets.text()funkcja renderuje widżety w notatniku. Jest podobny do elementu formularza pola tekstowego w HTML. Obiekt tego widżetu maon_submit() metoda, która nasłuchuje aktywności pola tekstowego i może wywołać procedurę obsługi zdarzeń podaną jako argument.

Przycisk

Ten widget jest podobny do przycisku HTML. Po kliknięciu zdarzenie jest rejestrowane przezon_click() metoda, która wywołuje procedurę obsługi zdarzenia kliknięcia.

IntSlider

Suwak, który wyświetla zwiększające się wartości całkowite. Istnieje również FloatSlider i IntRangeSlider (zmiana liczby całkowitej między zakresem)

Etykieta

Ten widget jest przydatny do wyświetlania tekstu nieedytowalnego w notatniku.

pokaz()

Ta funkcja z ipywidgets moduł renderuje obiekt widgetu w komórce wejściowej notatnika.

Oddziaływać

Ta funkcja automatycznie renderuje widżet w zależności od typu podanego argumentu danych. Pierwszym argumentem tej funkcji jest procedura obsługi zdarzeń, a drugim wartość przekazywana do samej procedury obsługi zdarzeń.

Poniższy przykład przedstawia trzy widżety etykiet, dwa widżety tekstowe i przycisk z podpisem „dodaj”. Po kliknięciu przycisku suma liczb w dwóch polach wprowadzania tekstu jest wyświetlana na najniższej etykiecie.

W tym rozdziale wyjaśnijmy, jak rozpocząć pracę z QtConsole. Ten rozdział zawiera przegląd tego oprogramowania i wyjaśnia kroki jego instalacji.

Przegląd

Konsola Qt jest aplikacją GUI podobną do terminala IPython. Zawiera jednak szereg ulepszeń, które nie są dostępne w tekstowym terminalu IPython. Ulepszone funkcje to liczby w wierszu, edycja wielowierszowa z podświetlaniem składni, graficzne podpowiedzi itp. Konsola Qt może używać dowolnego jądra Jupyter, domyślnie jest to jądro IPython.

Instalacja

Jupyter QtConsole jest częścią Project Jupyter. Dystrybucja Anaconda już zawiera aplikację QTconsole. Aby zainstalować go indywidualnie, użyj polecenia pip, jak pokazano poniżej -

pip3 install qtconsole

W tym celu możesz również użyć polecenia conda -

conda install qtconsole

Możesz uruchomić konsolę Jupyter z nawigatora Anaconda. Aby uruchomić go z wiersza poleceń, należy użyć następującego polecenia, albo z wiersza polecenia systemu Windows, albo z wiersza polecenia Anaconda -

jupyter qtonsole

Otrzymujesz terminal podobny do terminala IPython z pierwszym znakiem zachęty In []. Możesz teraz wykonać dowolne wyrażenie Pythona dokładnie tak, jak robimy to w terminalu IPython lub notatniku Jupyter

Edycja wielowierszowa to jedna z funkcji niedostępnych w terminalu IPython. Aby wprowadzić więcej niż jedną instrukcję w jednej komórce wejściowej, naciśnijctrl+enterpo pierwszej linii. Następnie naciśnięcie klawisza Enter spowoduje dodanie nowej linii w tej samej komórce. Aby zakończyć wprowadzanie nowych linii i uruchomioną komórkę, naciśnij klawisz Enter jeszcze raz na końcu. Komórka zostanie uruchomiona, a dane wyjściowe zostaną wyświetlone w następnej komórce out [].

Kolejnym ważnym ulepszeniem oferowanym przez QtConsole jest możliwość wyświetlania grafiki w wierszu, zwłaszcza wykresów. Ta funkcja działa dobrze z Matplotlib, a także z innymi bibliotekami wydruku.

Ta opcja zapisywania wyników QtConsole jako pliku HTML jest dostępna w menu Plik. Możesz wybrać, czy chcesz utworzyć plik z wbudowanym obrazem lub wydrukowaną figurą jako zewnętrzny plik png w sąsiednim folderze (o nazwie qt_files).

W aplikacji konsoli Jupyter możesz otworzyć więcej niż jedną zakładkę. W tym celu dostępne są trzy opcje w menu Plik.

  • New Tab with New kernel - Możesz załadować nowe jądro za pomocą tego menu plików.

  • New Tab with Existing kernel - Używając tej opcji, możesz wybierać spośród dodatkowych jąder oprócz jądra IPython.

  • New Tab with Same Kernel- Tworzy to slave jądra załadowanego na określonej karcie. W rezultacie obiekt zainicjowany na karcie głównej będzie dostępny w slave i odwrotnie.

Dostępna jest magiczna komenda% qtconsole do użycia z notatnikiem Jupyter. Wywołuje to QtConsole jako terminal podrzędny do nakładki na notebooka. W rezultacie dane między notebookiem a terminalem Qtconsole mogą być udostępniane.

Możesz zobaczyć, że zmienna w notatniku jest dostępna w qtconsoleokno. Ponadto nowa zmienna w Qtconsole jest używana w notebooku.

Zauważ, że komórki wejściowe i wyjściowe są numerowane przyrostowo między nimi.

Sharing Jupyter notebook – Using github and nbviewer

Pliki Jupyter Notebook z rozszerzeniem .ipynbrozszerzenie w repozytorium GitHub będzie renderowane jako statyczne pliki HTML po ich otwarciu. Interaktywne funkcje notatnika, takie jak niestandardowe wykresy JavaScript, nie będą działać w Twoim repozytorium na GitHub.

Aby udostępnić plik notatnika za pomocą github, zaloguj się do https://github.comi utwórz publiczne repozytorium. Następnie prześlij swoje pliki za pomocą przycisku przesyłania pliku, jak pokazano poniżej -

To da ci możliwość zatwierdzenia zmian dokonanych w repozytorium. Następnie repozytorium pokaże przesłany plik jak poniżej -

Kliknij przesłany plik, aby wyświetlić w przeglądarce github. Możesz udostępniać podświetlony adres URL innym osobom.

Innym sposobem przeglądania pliku notatnika w trybie online jest użycie narzędzia nbviewer Project Jupyter. otwartyhttps://nbviewer.jupyter.org/i umieść URL pliku w repozytorium w polu tekstowym, jak pokazano. Naciśnij przycisk Go, aby wyświetlić notatnik.

Obie te metody wyświetlają plik notatnika jako statyczny html. Aby móc wykonać kod w notatniku, otwórz go za pomocą aplikacji Binder projektu Jupyter.

W oknie nbviewer zobaczysz przycisk „Wykonaj na Binderze”. Kliknij go, a zobaczysz plik notatnika otwarty dokładnie tak, jak otwierasz go z lokalnego pulpitu nawigacyjnego serwera notebooków na komputerze lokalnym. Możesz wykonywać wszystkie czynności, takie jak dodawanie / edycja komórek, uruchamianie komórek itp.

Projekt Jupyter opisuje JupyterLab jako internetowe interfejsy użytkownika nowej generacji dla wszystkich produktów w ekosystemie Jupyter. Umożliwia bezproblemową pracę z notebookiem, edytorami i terminalami w rozszerzalny sposób.

Poniżej omówiono niektóre z ważnych funkcji JupyterLab -

  • Konsola kodu działa jako brudnopis do interaktywnego uruchamiania kodu. Ma pełne wsparcie dla bogatych danych wyjściowych i może być połączony z jądrem notebooka w celu rejestrowania aktywności notebooka.

  • Każdy plik tekstowy (Markdown, Python, R, LaTeX itp.) Można uruchomić interaktywnie w dowolnym jądrze Jupyter.

  • Dane wyjściowe komórki notebooka można wyświetlać na własnej karcie lub razem z notatnikiem, umożliwiając proste pulpity nawigacyjne z interaktywnymi kontrolkami wspieranymi przez jądro.

  • Edycja dokumentu na żywo jest odzwierciedlana w innych przeglądarkach, takich jak edytory lub konsole. Możliwy jest podgląd na żywo dokumentów Markdown, wartości oddzielonych separatorem lub dokumentów Vega / Vega-Lite.

JupyterLab obsługuje wiele formatów plików (obrazy, CSV, JSON, Markdown, PDF itp.). Wyświetla również bogate wyniki w tych formatach. JupyterLab zapewnia konfigurowalne skróty klawiaturowe, wykorzystując mapy klawiszy z wielu znanych edytorów tekstu.

Możesz wypróbować online funkcje JupyterLab przed instalacją. Wizytahttps://jupyter.org/try i wybierz opcję „wypróbuj JupyterLab”.

Zakładka uruchamiania pokazuje aktualnie dostępne jądra i konsole. Możesz rozpocząć nowy notebook oparty / terminal na podstawie dowolnego z nich. Lewa kolumna zawiera również zakładki dla przeglądarki plików, uruchomionych jąder i zakładek oraz widoku ustawień.

JupyterLab jest zwykle instalowany automatycznie z dystrybucją Anaconda. Jednak można go również zainstalować osobno, używając następującego polecenia conda -

conda install -c conda-forge jupyterlab

W tym celu możesz również użyć polecenia pip -

pip3 install jupyterlab

Aby uruchomić aplikację JupyterLab, najwygodniej jest użyć programu Anaconda Navigator, jeśli jest zainstalowany.

Alternatywnie uruchom go z wiersza poleceń z terminala poleceń systemu Windows / Linux lub wiersza polecenia Anaconda za pomocą tego polecenia -

jupyter lab

Tak czy inaczej, ekran uruchamiania aplikacji JupyterLab wygląda następująco -

Aby rozpocząć nowy notatnik, kliknij żądane jądro. Na powyższym zrzucie ekranu widać jedno jądro, które jest jądrem Python3. Kliknij, aby uruchomić notatnik Pythona. Zauważ, że jego funkcjonalność jest podobna do tej, którą badaliśmy w tym samouczku.

Pasek menu

Pasek menu znajduje się u góry okna. Domyślne menu, które można w tym znaleźć, to -

  • File - Działania związane z plikami i katalogami.

  • Edit - Działania związane z edycją dokumentów i innymi czynnościami.

  • View - Działania zmieniające wygląd JupyterLab.

  • Run - Działania związane z uruchamianiem kodu w różnych działaniach, takich jak notebooki i konsole kodu.

  • Kernel - Akcje zarządzania jądrem, które są oddzielnymi procesami do uruchamiania kodu.

  • Tabs - Lista otwartych dokumentów i działań w panelu dokowania.

  • Settings - Ustawienia wspólne i zaawansowany edytor ustawień.

  • Help - Lista linków do pomocy JupyterLab i jądra.

Lewy pasek boczny zawiera przyciski do uruchamiania nowego programu uruchamiającego, dodawania folderu, przesyłania plików i odświeżania listy plików. Prawy panel to główny obszar roboczy, w którym notebook, konsola i terminale są pokazane w widoku z zakładkami.

Aby uruchomić nową konsolę, kliknij symbol + na lewym pasku bocznym, aby otworzyć nowy program uruchamiający, a następnie kliknij opcję konsoli. Konsola otworzy się w nowej karcie w prawym okienku.

Zwróć uwagę, że komórka wejściowa znajduje się na dole, ale po uruchomieniu komórka i odpowiadająca jej komórka wyjściowa pojawiają się w górnej części karty konsoli.

Program uruchamiający umożliwia również otwarcie edytora tekstu i terminala, w którym można wywołać powłokę IPython.

Projekt Jupyter obsługuje teraz jądra środowisk programistycznych. Zobaczymy teraz, jak zainstalować jądro R w dystrybucji anaconda.

W oknie wiersza polecenia Anaconda wprowadź następujące polecenie -

conda install -c r r-essentials

Teraz na karcie uruchamiania wybierz jądro R, aby rozpocząć nowy notatnik.

Poniżej znajduje się zrzut ekranu notebooka Jupyter z jądrem R -