Skip to main content

A python interface for training Reinforcement Learning bots to battle on pokemon showdown.

Project description

Poke-env: Python Interface for Pokemon Showdown Bots

PyPI version fury.io PyPI pyversions License: MIT Documentation Status codecov

poke-env is a Python library for building scripted agents, self-play experiments, and reinforcement learning workflows on Pokemon Showdown.

A simple agent in action

Installation

This project requires Python >= 3.10 and access to a Pokemon Showdown server. For training and local development, running your own server is strongly recommended.

pip install poke-env

You can use smogon's server to try out your agents against humans, but having a development server is strongly recommended. In particular, it is recommended to use the --no-security flag to run a local server with most rate limiting and throttling turned off. Please refer to the docs for detailed setup instructions.

git clone https://github.com/smogon/pokemon-showdown.git
cd pokemon-showdown
npm install
cp config/config-example.js config/config.js
node pokemon-showdown start --no-security

First local battle

Once your local server is running, the quickest way to verify your setup is to run two built-in players against each other. RandomPlayer uses the default localhost server configuration, so this script should work as-is:

import asyncio

from poke_env.player import RandomPlayer


async def main():
    player_1 = RandomPlayer(max_concurrent_battles=1)
    player_2 = RandomPlayer(max_concurrent_battles=1)

    await player_1.battle_against(player_2, n_battles=1)

    print(f"Finished battles: {player_1.n_finished_battles}")
    print(f"Player 1 wins: {player_1.n_won_battles}")


if __name__ == "__main__":
    asyncio.run(main())

To build your own bot, subclass Player and override choose_move. The quickstart guide walks through that step by step.

Documentation and examples

Documentation, detailed examples, and starting code are available on Read the Docs.

Useful entry points:

Development version

You can also clone the latest master version with:

git clone https://github.com/hsahovic/poke-env.git

Dependencies and development dependencies can then be installed with:

cd poke-env
uv sync --dev

Run development commands through uv run, for example uv run pytest unit_tests/.

Acknowledgements

This project is a follow-up of a group project from an artificial intelligence class at Ecole Polytechnique.

You can find the original repository here. It is partially inspired by the showdown-battle-bot project. Of course, none of these would have been possible without Pokemon Showdown.

Team data comes from Smogon forums' RMT section.

Data

Data files are adapted versions of the js data files from Pokemon Showdown.

License

License: MIT

Citing poke-env

@misc{poke_env,
    author       = {Haris Sahovic},
    title        = {Poke-env: pokemon AI in python},
    url          = {https://github.com/hsahovic/poke-env}
}

Download files

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

Source Distribution

poke_env-0.15.0.tar.gz (1.2 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

poke_env-0.15.0-py3-none-any.whl (1.4 MB view details)

Uploaded Python 3

File details

Details for the file poke_env-0.15.0.tar.gz.

File metadata

  • Download URL: poke_env-0.15.0.tar.gz
  • Upload date:
  • Size: 1.2 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.3

File hashes

Hashes for poke_env-0.15.0.tar.gz
Algorithm Hash digest
SHA256 15ed408dd48885d9d589dfda3616ace329a38682992af9b283bf3309b2fce486
MD5 7f170e89772e1a97a061d029876da9d8
BLAKE2b-256 abbcf1977f42261f45e185402d7ea06741bbeb24791b1f7a79902bcf6853f4eb

See more details on using hashes here.

File details

Details for the file poke_env-0.15.0-py3-none-any.whl.

File metadata

  • Download URL: poke_env-0.15.0-py3-none-any.whl
  • Upload date:
  • Size: 1.4 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.3

File hashes

Hashes for poke_env-0.15.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6d2d60f95f93e36a40f8f4af9bb7440b4bd068def9859d4c53b2ac57ae202b11
MD5 de8d672123bdbe20520ea65f7e0081e1
BLAKE2b-256 352e2825f5b79354a0440a87debb6fda9921950224771167d077d811801dcf99

See more details on using hashes here.

Supported by

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