Buscar..


Introducción

IPython extiende Python con un conjunto de comandos llamados magics . Estas son funciones especiales cuyos nombres comienzan con un % reconocido por el shell de IPython. Las magias cuyo nombre comienza con solo un % toman como argumento el resto de la línea y se llaman magias de línea . Las magias que comienzan con un signo de porcentaje doble %% toman un argumento de varias líneas y se llaman magias de celdas .

Las magias% timeit y `% time`

El %timeit magic ejecuta el código dado muchas veces, luego devuelve la velocidad del resultado más rápido.

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

La magia celular %%timeit puede usarse para %%timeit bloques de código.

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

El %time mágico veces una única ejecución de una función, similar al comando de time Unix. A diferencia de %timeit , %time también muestra el resultado.

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

Línea incorporada y magias celulares

Las magias cuyo nombre comienza con solo un % toman como argumento el resto de la línea y se llaman magias de línea . Las magias que comienzan con un signo de porcentaje doble %% toman un argumento de varias líneas y se llaman magias de celdas .

Una magia de uso común es %timeit , una envoltura alrededor de la función timeit.timeit de Python, para medir el tiempo de ejecución de un fragmento de código.

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 ejemplo de magia celular es %%bash (equivalente a %%script bash ) para ejecutar la entrada como código bash

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

Tenga en cuenta que el final de una celda está marcado por una línea vacía.

Para ver todas las magias incorporadas usa %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.

Tenga en cuenta que, por defecto, 'automágico' está activado y, por lo tanto, se puede llamar a las magias de línea sin el prefijo % (pero las funciones de las celdas aún necesitan un prefijo %% ).



Modified text is an extract of the original Stack Overflow Documentation
Licenciado bajo CC BY-SA 3.0
No afiliado a Stack Overflow