サーチ…
前書き
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は、複数行の引数をとり、 セルマジックと呼ばれます。
一般的に使用される魔法は%timeit
のtimeit.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