Recherche…


Introduction

IPython étend Python avec un ensemble de commandes appelées magiques . Ce sont des fonctions spéciales dont les noms commencent par un % reconnu par le shell IPython. Les magiques dont le nom commence par un % prennent comme argument le reste de la ligne et sont appelées magie de ligne . Les magiques qui commencent par un signe de pourcentage double %% prennent un argument multi-ligne et sont appelées magie cellulaire .

Les magiques% timeit et% time

La magie %timeit exécute le code donné plusieurs fois, puis renvoie la vitesse du résultat le plus rapide.

In [1]: %timeit sum(range(100000))
100 loops, best of 3: 2.91 ms per loop

La magie de cellule %%timeit peut être utilisée pour chronométrer des blocs de code.

In [2]: %%timeit
   ...: a = 0
   ...: for i in range(100000):
   ...:     a += i
   ...:
100 loops, best of 3: 9.67 ms per loop

La magie %time multiplie par une seule exécution d'une fonction, similaire à la commande time Unix. Contrairement à %timeit , %time affiche également le résultat.

In [3]: %time sum(range(100000))
CPU times: user 2.68 ms, sys: 3 µs, total: 2.68 ms
Wall time: 2.69 ms
Out[3]: 4999950000

Ligne intégrée et magie cellulaire

Les magiques dont le nom commence par un % prennent comme argument le reste de la ligne et sont appelées magie de ligne . Les magiques qui commencent par un signe de pourcentage double %% prennent un argument multi-ligne et sont appelées magie cellulaire .

Une magie couramment utilisée est %timeit , une enveloppe autour de la fonction timeit.timeit de Python, pour mesurer le temps d'exécution d'un morceau de code.

In [35]: ra = [random.randint(0,1000) for r in range(1000)]
In [35]: %timeit sorted(ra)
1000 loops, best of 3: 507 µs per loop

Un exemple de magie de cellule est %%bash (équivalent à %%script bash ) pour exécuter l'entrée en tant que code bash

In [49]: %%bash
    ...: i=3
    ...: while [ $i -ge 0 ]
    ...: do
    ...: echo $i
    ...: i=$(($i-1))
    ...: done
    ...:
3
2
1
0

Notez que la fin d'une cellule est marquée par une ligne vide.

Pour afficher toutes les magies %lsmagic utilisez %lsmagic

In [51]: %lsmagic
Out[51]:
Available line magics:
%alias  %alias_magic  %autocall  %autoindent  %automagic  %bookmark  %cd  %cls
%colors  %config  %copy  %cpaste  %ddir  %debug  %dhist  %dirs  %doctest_mode  
%echo  %ed  %edit  %env  %gui  %hist  %history  %killbgscripts  %ldir  %load  
%load_ext  %loadpy  %logoff  %logon  %logstart  %logstate  %logstop  %ls  %lsmagic
%macro  %magic  %matplotlib  %mkdir  %notebook  %page  %paste  %pastebin  %pdb
%pdef  %pdoc  %pfile  %pinfo  %pinfo2  %popd  %pprint  %precision  %profile  
%prun  %psearch  %psource  %pushd  %pwd  %pycat  %pylab  %quickref  %recall  
%rehashx  %reload_ext  %ren  %rep  %rerun  %reset  %reset_selective  %rmdir  %run  
%save  %sc  %set_env  %store  %sx  %system  %tb  %time  %timeit  %unalias  
%unload_ext  %who  %who_ls  %whos  %xdel  %xmode

Available cell magics:
%%!  %%HTML  %%SVG  %%bash  %%capture  %%cmd  %%debug  %%file  %%html  
%%javascript  %%js  %%latex  %%perl  %%prun  %%pypy  %%python  %%python2  %%python3  
%%ruby  %%script  %%sh  %%svg  %%sx  %%system  %%time  %%timeit  %%writefile

Automagic is ON, % prefix IS NOT needed for line magics.

Notez que par défaut, "automagic" est activé, et donc les magiques de ligne peuvent être appelées sans % prefix (mais les fonctions de cellule ont toujours besoin d'un préfixe %% ).



Modified text is an extract of the original Stack Overflow Documentation
Sous licence CC BY-SA 3.0
Non affilié à Stack Overflow