Skip to main content

ChatterBot is a machine learning, conversational dialog engine.

Project description

.. figure:: http://i.imgur.com/b3SCmGT.png
:alt: Chatterbot: Machine learning in Python

Chatterbot: Machine learning in Python

ChatterBot
==========

ChatterBot is a machine-learning based conversational dialog engine
build in Python which makes it possible to generate responses based on
collections of known conversations. The language independent design of
ChatterBot allows it to be trained to speak any language.

*`Read in English <readme.md>`__* *`Leia em Português <readme.pt.md>`__*
*`Leer en español <readme.es.md>`__*

|Package Version| |Requirements Status| |Build Status| |Documentation
Status| |Coverage Status| |Code Climate| |Join the chat at
https://gitter.im/chatter\_bot/Lobby|

An example of typical input would be something like this:

| **user:** Good morning! How are you doing?
| **bot:** I am doing very well, thank you for asking.
| **user:** You're welcome.
| **bot:** Do you like hats?

How it works
------------

An untrained instance of ChatterBot starts off with no knowledge of how
to communicate. Each time a user enters a statement, the library saves
the text that they entered and the text that the statement was in
response to. As ChatterBot receives more input the number of responses
that it can reply and the accuracy of each response in relation to the
input statement increase. The program selects the closest matching
response by searching for the closest matching known statement that
matches the input, it then returns the most likely response to that
statement based on how frequently each response is issued by the people
the bot communicates with.

Installation
------------

This package can be installed from
`PyPi <https://pypi.python.org/pypi/ChatterBot>`__ by running:

::

pip install chatterbot

Basic Usage
-----------

::

from chatterbot import ChatBot

chatbot = ChatBot(
'Ron Obvious',
trainer='chatterbot.trainers.ChatterBotCorpusTrainer'
)

# Train based on the english corpus
chatbot.train("chatterbot.corpus.english")

# Get a response to an input statement
chatbot.get_response("Hello, how are you today?")

Training data
=============

Chatterbot comes with a data utility module that can be used to train
chat bots. At the moment there is three languages, English, Spanish and
Portuguese training data in this module. Contributions of additional
training data or training data in other languages would be greatly
appreciated. Take a look at the data files in the
`chatterbot/corpus <https://github.com/gunthercox/ChatterBot/tree/master/chatterbot/corpus>`__
directory if you are interested in contributing.

::

# Train based on the english corpus
chatbot.train("chatterbot.corpus.english")

# Train based on english greetings corpus
chatbot.train("chatterbot.corpus.english.greetings")

# Train based on the english conversations corpus
chatbot.train("chatterbot.corpus.english.conversations")

**Corpus contributions are welcome! Please make a pull request.**

`Documentation <http://chatterbot.readthedocs.io/>`__
=====================================================

View the `documentation <http://chatterbot.readthedocs.io/>`__ for
ChatterBot on Read the Docs.

To build the documentation yourself using
`Sphinx <http://www.sphinx-doc.org/>`__, run:

::

sphinx-build -b html docs/ build/

Examples
========

For examples, see the
`examples <https://github.com/gunthercox/ChatterBot/tree/master/examples>`__
directory in this project's git repository.

There is also an example `Django project using
ChatterBot <https://github.com/gunthercox/django_chatterbot>`__, as well
as an example `Flask project using
ChatterBot <https://github.com/chamkank/flask-chatterbot>`__.

History
=======

See release notes for changes
https://github.com/gunthercox/ChatterBot/releases

Development pattern for contributors
====================================

1. `Create a fork <https://help.github.com/articles/fork-a-repo/>`__ of
the `main ChatterBot
repository <https://github.com/gunthercox/ChatterBot>`__ on GitHub.
2. Make your changes in a branch named something different from
``master``, e.g. create a new branch ``my-pull-request``.
3. `Create a pull
request <https://help.github.com/articles/creating-a-pull-request/>`__.
4. Please follow the `Python style guide for
PEP-8 <https://www.python.org/dev/peps/pep-0008/>`__.
5. Use the projects `built-in automated
testing <http://chatterbot.readthedocs.io/en/latest/testing.html>`__
to help make sure that your contribution is free from errors.

License
=======

ChatterBot is licensed under th `BSD 3-clause
license <https://opensource.org/licenses/BSD-3-Clause>`__.

.. |Package Version| image:: https://img.shields.io/pypi/v/chatterbot.svg
:target: https://pypi.python.org/pypi/chatterbot/
.. |Requirements Status| image:: https://requires.io/github/gunthercox/ChatterBot/requirements.svg?branch=master
:target: https://requires.io/github/gunthercox/ChatterBot/requirements/?branch=master
.. |Build Status| image:: https://travis-ci.org/gunthercox/ChatterBot.svg?branch=master
:target: https://travis-ci.org/gunthercox/ChatterBot
.. |Documentation Status| image:: https://readthedocs.org/projects/chatterbot/badge/?version=stable
:target: http://chatterbot.readthedocs.io/en/stable/?badge=stable
.. |Coverage Status| image:: https://img.shields.io/coveralls/gunthercox/ChatterBot.svg
:target: https://coveralls.io/r/gunthercox/ChatterBot
.. |Code Climate| image:: https://codeclimate.com/github/gunthercox/ChatterBot/badges/gpa.svg
:target: https://codeclimate.com/github/gunthercox/ChatterBot
.. |Join the chat at https://gitter.im/chatter\_bot/Lobby| image:: https://badges.gitter.im/chatter_bot/Lobby.svg
:target: https://gitter.im/chatter_bot/Lobby?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distributions

ChatterBot-0.5.2.zip (113.1 kB view details)

Uploaded Source

ChatterBot-0.5.2.tar.gz (73.6 kB view details)

Uploaded Source

ChatterBot-0.5.2.linux-x86_64.tar.gz (125.0 kB view details)

Uploaded Source

Built Distribution

ChatterBot-0.5.2-py2.py3-none-any.whl (108.9 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file ChatterBot-0.5.2.zip.

File metadata

  • Download URL: ChatterBot-0.5.2.zip
  • Upload date:
  • Size: 113.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for ChatterBot-0.5.2.zip
Algorithm Hash digest
SHA256 d6c2052e5c4f9c43871aacf438228a9d9944a78f020eac1ab3b50950f6da76c9
MD5 ea2a337c3f1af7885d86ad2ba9c18289
BLAKE2b-256 6f450c3a6abf6270a21168ee0c86195c93380c56a3e54e126d49774dec2da139

See more details on using hashes here.

File details

Details for the file ChatterBot-0.5.2.tar.gz.

File metadata

  • Download URL: ChatterBot-0.5.2.tar.gz
  • Upload date:
  • Size: 73.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for ChatterBot-0.5.2.tar.gz
Algorithm Hash digest
SHA256 4d59573d857fdc40057e12b4625c595a3af704484f11ff95dd14c2d62f1465c0
MD5 237844018d880303a314fb236fa7ddb7
BLAKE2b-256 d5cdbcbe76f201d937e3e20497c76e376a4f073c6b26eec338343809193d708e

See more details on using hashes here.

File details

Details for the file ChatterBot-0.5.2.linux-x86_64.tar.gz.

File metadata

File hashes

Hashes for ChatterBot-0.5.2.linux-x86_64.tar.gz
Algorithm Hash digest
SHA256 5fbdb7ba5af2ce57087d973103f85af3c9e5c26f03075555d8b57bfeccbdfa45
MD5 c7b794fc3fb175cc4dd1bc130547aab5
BLAKE2b-256 641529466ef79b20fcfc6e38aa1c267ae2bc098ecff398af967c9d02f4095e21

See more details on using hashes here.

File details

Details for the file ChatterBot-0.5.2-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for ChatterBot-0.5.2-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 db68e2ef6715f82900c1bf92294815fd7fc42b0d3d8946ddc49c6a924159f8b1
MD5 96caf8f1bf0c91614093c57d1e0b2176
BLAKE2b-256 dec4b7d2001a4ca7bd4b6267656f008987972ddd09332c74c8da9fcef7b5aff4

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page