サーチ…


前書き

IPythonは、 magicsと呼ばれる一連のコマンドでPythonを拡張します。これらは、名前がIPythonシェルによって認識される%で始まる特別な関数です。名前がちょうど1 %始まる魔法は、残りの行を引数としてとり、 行魔法と呼ばれます。二重パーセント記号%%で始まるMagicsは、複数行の引数をとり、 セルマジックと呼ばれます。

%timeitと `%time`のマジック

%timeitマジックは与えられたコードを何度も実行し、次に最も速い結果のスピードを返します。

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

%%timeitセルマジックを使用して、コードブロックの時間を%%timeitことができます。

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

%time魔法は、Unixのtimeコマンドに似た、関数の1回の実行を掛けます。 %timeitとは異なり、 %timeも結果を表示します。

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

ビルトインのラインとセルマジック

名前がちょうど1 %始まる魔法は、残りの行を引数としてとり、 行魔法と呼ばれます。二重パーセント記号%%で始まるMagicsは、複数行の引数をとり、 セルマジックと呼ばれます。

一般的に使用される魔法は%timeittimeit.timeit関数を包むラッパーで、コードの実行時間を測定します。

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

セルマジックの例は、入力をbashコードとして実行するための%%bash%%script bash相当)です

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

セルの終わりに空の行があることに注意してください。

組み込みの魔法をすべて表示するには、 %lsmagic使用します%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.

デフォルトでは 'automagic'がオンになっているので、ラインマジックは%プレフィックスなしで呼び出すことができます(ただし、セル関数には%%プレフィックスが必要です)。



Modified text is an extract of the original Stack Overflow Documentation
ライセンスを受けた CC BY-SA 3.0
所属していない Stack Overflow