Skip to content

♠️♦️ Generate Anki decks for memorizing Poker preflop ranges.

License

Notifications You must be signed in to change notification settings

omarkohl/anki-poker-master

Repository files navigation

AnkiPokerMaster

Python tool to generate one or multiple Anki decks for memorizing Texas Hold'em Poker preflop ranges.

Anki is a powerful tool to learn and memorize useful information. It is available for Windows, Linux, macOS, Android and iOS. Official website and inspiring examples of the power of Anki.

You can read some more about Poker preflop ranges here and here.

PyPI - Version

Usage

Install using pip:

pip install anki_poker_master

Write a YAML file to define all scenarios (situations) you want to memorize, for example "Opening as Button in a 100BB Cash game". AnkiPokerMaster will generate Anki decks based solely on this scenario.yml file and you will get Anki cards like the screenshots below.

- game: "Cash 100BB 6P"
  position: "LJ"
  scenario: "Opening"
  ranges:
    Raise: "A2s+, K5s+, Q9s+, JTs, T9s, ATo+, KJo+, QJo+, 77+"
  source: pokertrainer.se

See a more complex example here: example_scenarios.yml

anki-poker-master -s scenarios.yml -o Poker.apkg

Poker.apkg is a regular Anki package file and can be imported into Anki.

Execute anki-poker-master --help to see more usage information.

Ranges

Some examples for how ranges can be specified:

  • 77+ (All pairs 77 and up i.e. 77, 88, 99, ...)
  • 77- (All pairs 77 and below i.e. 77, 66, 55, ...)
  • A2s+ (A2 suited and up excluding pairs i.e. A2s, A3s, A4s, ...)
  • KT+ (KT and up both suited and offsuit excluding pairs i.e. KTs, KJs, KQs, KTo, KJo and KQo)
  • 23s (A specific hand i.e. 23s)
  • 95s-98s (Hands between i.e. 95s, 96s, 97s and 98s)
  • Combining any of the above separated by commas

Screenshots

When opening as the small blind, how should you play King Three offsuit?

Answer:

When opening as Lojack, how should you play Jack and another suited card?

Answer:

What table position does the following range table correspond to? (this question is a memorization aid)

Answer:

Fill in the blank cells in this range table.

Note that here it's possible to mark cells using the mouse or finger (touchscreen) as a memory aid before flipping to the answer side.

Answer:

Of course also with dark mode: How should you open with QQ as Hijack?

Answer:

Develop

Check the repository on GitHub: https://github.com/omarkohl/anki-poker-master

poetry install
poetry run anki-poker-master
# poetry shell

Tests

poetry run pytest

Most of the tests generate output that is compared with golden files (i.e. files containing the expected output). This has the big advantage that you can look at these files easily to see what the functions actually generate. Looking at the HTML files in a browser gives you the full experience.

If you modify the code instead of having to manually fix all golden files you can run the following command to overwrite them all. Obviously you should only do this if you understand what you are changing.

poetry run pytest --update-golden

Occasionally you should delete all golden files and re-generate them to make sure there are no orphaned files lying around because a test was renamed or deleted:

rm -rf tests/golden
poetry run pytest --update-golden

Manual tests

Currently some tests are not automated because they would require programatically evaluating Anki decks. For now doing it manually is simpler. The tests will interactively guide you.

APM_MANUAL_TESTS=true poetry run pytest tests/test_manual.py -s

Support

Raise any issues on GitHub.

License

Unless otherwise specified, the code is under the MIT license and the card images are published under LGPL 3.0 (see below for original source of the card images).

Credits

Playing Cards

Slightly modified (see list of changes in playing-cards.svg) from original source:

Vector Playing Cards 3.2
https://totalnonsense.com/open-source-vector-playing-cards/
Copyright 2011,2021 – Chris Aguilar – conjurenation@gmail.com
Licensed under: LGPL 3.0 - https://www.gnu.org/licenses/lgpl-3.0.html

Inspiration

About

♠️♦️ Generate Anki decks for memorizing Poker preflop ranges.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published