Skip to main content
This is a pre-production deployment of Warehouse. Changes made here affect the production instance of PyPI (
Help us improve Python packaging - Donate today!

A Chatbot kernel for Jupyter based on pyAIML

Project Description

This is a Jupyter kernel that deploys a chatbot, implemented using the python-aiml package. The idea was taken from the Calysto chatbot kernel.

It has been tested with Jupyter 4.x. The code works with either Python 2.7 or Python 3 (tested with Python 3.4)


The installation process requires two steps:

  1. Install the Python package:

    pip install aimlbotkernel
  2. Install the kernel into Jupyter:

    jupyter aimlbotkernel install [--user] [--logdir <dir>]

The --user option will install the kernel in the current user’s personal config, while the generic command will install it as a global kernel (but needs write permissions in the system directories).

The --logdir specifies the default place into which the logfile will be written (unless overriden at runtime by the LOGDIR environment variable). If no directory is specified, the (platform-specific) default temporal directory will be used.

Note that the Jupyter kernel installation also installs some custom CSS; its purpose is to improve the layout of the kernel results as they are presented in the notebook (but it also means that the rendered notebook will look slightly different in a Jupyter deployment in which the kernel has not been installed, or within an online viewer).

To uninstall, perform the inverse operations (in reverse order), to uninstall the kernel from Jupyter and to remove the Python package:

jupyter aimlbotkernel remove
pip uninstall aimlbotkernel


Once installed, an AIML Chatbot kernel will be available in the Notebook New menu. Starting one such kernel will create a chatbot. The chatbot is initially empty but can be loaded with a couple of predefined DBs (use the %help magic for initial instructions).

Notebook input is of two kinds:

  • Regular text cells are considered human input and are sent to the chatbot, which produces its corresponding output
  • Cells starting with % contain “magic” commands that affect the operation of the kernel (load AIML databases, inspecting/modifying bot state, saving/loading state to/from disk, etc). Use the %help magic for some instructions, and %lsmagics to show the current list of defined magics (magics have autocompletion and contextual help).

The examples directory contains a few notebooks showing some of the provided functionality. They can also be seen with online Notebook viewer (note that, as said above, they will look slightly different than in a running kernel).


AIML is an XML-based specification to design conversational agents. Its most famous application is ALICE, a chatbot (the DB for the free version of ALICE is included in this kernel, as it is included in python-aiml)

The chatbot can load an AIML database (which is basically a bunch of XML files). It can also define AIML rules on the fly, by using the %aiml magic in a cell.

Release History

Release History

This version
History Node


History Node


History Node


History Node


Download Files

Download Files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

File Name & Checksum SHA256 Checksum Help Version File Type Upload Date
aimlbotkernel-1.0.4.tar.gz (27.3 kB) Copy SHA256 Checksum SHA256 Source Apr 20, 2017

Supported By

WebFaction WebFaction Technical Writing Elastic Elastic Search Pingdom Pingdom Monitoring Dyn Dyn DNS Sentry Sentry Error Logging CloudAMQP CloudAMQP RabbitMQ Heroku Heroku PaaS Kabu Creative Kabu Creative UX & Design Fastly Fastly CDN DigiCert DigiCert EV Certificate Rackspace Rackspace Cloud Servers DreamHost DreamHost Log Hosting