Если вы хотите запустить код в ядре из другой программы Python, проще всего подключить Менеджер ядра блокировки. Лучшим примером этого на данный момент является клиент vim-ipython Пола Иванова или собственный терминальный клиент.
Суть:
- Ядра ipython записывают файлы подключения JSON в
IPYTHONDIR/profile_<name>/security/kernel-<id>.json
, которые содержат информацию, необходимую различным клиентам для подключения и выполнения кода.
- KernelManagers — это объекты, которые используются для связи с ядрами (выполнение кода, получение результатов и т. д.). *
Рабочий пример:
В оболочке выполните ipython kernel
(или ipython qtconsole
, если вы хотите поделиться ядром с уже работающим графическим интерфейсом):
$> ipython kernel
[IPKernelApp] To connect another client to this kernel, use:
[IPKernelApp] --existing kernel-6759.json
Это написало файл «kernel-6759.json».
Затем вы можете запустить этот фрагмент Python, чтобы подключить KernelManager и запустить некоторый код:
from IPython.lib.kernel import find_connection_file
from IPython.zmq.blockingkernelmanager import BlockingKernelManager
# this is a helper method for turning a fraction of a connection-file name
# into a full path. If you already know the full path, you can just use that
cf = find_connection_file('6759')
km = BlockingKernelManager(connection_file=cf)
# load connection info and init communication
km.load_connection_file()
km.start_channels()
def run_cell(km, code):
# now we can run code. This is done on the shell channel
shell = km.shell_channel
print
print "running:"
print code
# execution is immediate and async, returning a UUID
msg_id = shell.execute(code)
# get_msg can block for a reply
reply = shell.get_msg()
status = reply['content']['status']
if status == 'ok':
print 'succeeded!'
elif status == 'error':
print 'failed!'
for line in reply['content']['traceback']:
print line
run_cell(km, 'a=5')
run_cell(km, 'b=0')
run_cell(km, 'c=a/b')
Результат прогона:
running:
a=5
succeeded!
running:
b=0
succeeded!
running:
c=a/b
failed!
---------------------------------------------------------------------------
ZeroDivisionError Traceback (most recent call last)
/Users/minrk/<ipython-input-11-fb3f79bd285b> in <module>()
----> 1 c=a/b
ZeroDivisionError: integer division or modulo by zero
см. спецификацию сообщения для получения дополнительной информации о том, как интерпретировать ответ. При необходимости данные stdout/err и display будут поступать через km.iopub_channel
, и вы можете использовать msg_id, возвращаемый shell.execute()
, чтобы связать вывод с данным выполнением.
PS: приношу свои извинения за качество документации этих новых функций. Нам нужно много писать.
person
minrk
schedule
02.04.2012