Skip to main content

High level Python framework for building Minecraft clients and bots

Project description

Build Status Docs Status Coverage Status

SpockBot currently supports Minecraft 1.8.8

Minecraft bot framework written in Python, currently under heavy development.

Client could loosely be called “event-driven”. By default plugins register handler functions to handle events that may or may not be emitted by other plugins. Everything is a plugin in SpockBot, including the event loop/framework itself, so you can feel free to rip out the entire back end and replace it with your framework or paradigm of choice. As long as you provide the same simple APIs, other plugins won’t know the difference.

We’re only just getting started with documentation so if you’re uncomfortable reading source code this might not be the framework for you. Or, better yet, hop on IRC and help us write some docs!

SpockBot officially supports Python 3.x and Python 2.7.x on *nix operating systems and requires cryptography. It also runs on Windows and under PyPy 2.6.x but that’s not regularly tested and could be broken at any given moment. If you support one of those use cases and SpockBot breaks for you, submit an issue with a stack trace and we’ll try to fix it.

Features

  • World Interaction (finding, placing, breaking)
  • Vanilla Physics
  • Pathfinding
  • Inventory (player, chests, etc)
  • Crafting
  • Entity Tracking

Dependencies

Installation

python3 setup.py install

Note: The cryptography library has some extra dependencies to install, you can find detailed instructions here.

Documentation

Current docs live here https://spockbot.readthedocs.org

Examples

Refer to the example bot for instructions on how to write a bot and a plugin that provides some common functionality.

Also see Extra examples and Bat bot for additional examples.

Projects Using SpockBot

Support

#spockbot on Freenode
gamingrobot or nickelpro in #mcdevs on Freenode

Contributing

Instructions for contributing to SpockBot can be found in CONTRIBUTING

Credits

Inspired by remyroy’s COPS, a Minecraft client in Python.

COPS was a service that tracked players on a minecraft server called Civcraft. It looked like this

Protocol implementation based on barneymc.

Project details


Download files

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

Files for spockbot, version 0.1.5
Filename, size File type Python version Upload date Hashes
Filename, size spockbot-0.1.5-py2.py3-none-any.whl (81.8 kB) File type Wheel Python version py2.py3 Upload date Hashes View hashes
Filename, size spockbot-0.1.5-py3.4.egg (200.9 kB) File type Egg Python version 3.4 Upload date Hashes View hashes
Filename, size spockbot-0.1.5.tar.gz (73.5 kB) File type Source Python version None Upload date Hashes View hashes

Supported by

Elastic Elastic Search Pingdom Pingdom Monitoring Google Google BigQuery Sentry Sentry Error logging AWS AWS Cloud computing DataDog DataDog Monitoring Fastly Fastly CDN DigiCert DigiCert EV certificate StatusPage StatusPage Status page