pyrcb2 is an asyncio-based library for writing IRC bots. It is designed to be easy to use, customizable, and high-level.
pyrcb2 includes features such as account tracking, user prefix tracking (voice, op, etc.), messaging delaying to prevent throttling, and long message splitting.
pyrcb2 also makes use of asyncio and coroutines in Python. This allows you to write asynchronous code in a linear fashion—you can handle responses to commands right after you send them.
# Wait until the bot has joined #channel.
await bot.join("#channel")
print("There are", len(bot.users["#channel"]), "users in #channel.")
# Get user1's account.
result = await bot.get_account("user1")
if result.success:
account = result.value or "(no account)"
print("user1 is logged in as", account)
Install with pip:
$ pip3 install pyrcb2
Or clone and install with setup.py
:
$ ./setup.py install
Alternatively, you can clone and install with pip:
$ pip3 install .
You will need to run the commands above as root if you're installing globally.
You can use the --user
option to install to your home directory instead.
Documentation for pyrcb2 is available at https://taylor.fish/pyrcb2/. If you're new to pyrcb2, start with this guide and take a look at the examples.
This branch contains the development version of pyrcb2.
See the stable
branch for the latest stable release.
pyrcb2 requires Python 3.7 or later.
To run pyrcb2's tests, run python3 -m tests
. If you have coverage
installed, you can run coverage run -m tests.__main__
to get information
on test coverage.
pyrcb2 is licensed under the GNU Lesser General Public License, version 3 or later. Some parts are released under other licenses; see the full license notice and individual files for details.