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 -