A library for evaluating tabletop dice roll expressions
Project description
PyHedrals 
A library for evaluating tabletop dice roll expressions.
Used in the Mastodon bot DiceCat, and the IRC bot DesertBot
Usage Overview
Sample usage:
5d6!>4 + (5d(2d10)dl - d10) * (d20 / 2) # for an unnecessarily complicated roll
Sample output:
84 for an unnecessarily complicated roll
There is also a verbose mode that outputs every individual die roll, that output looks like this:
[2d10: 2,5 (7) | 5d7: -1-,6,2,4,5 (17) | 1d10: 3 (3) | 1d20: 9 (9) | 5d6: 2,2,3,*5*,*5*,2,*5*,4 (28)] 84 for an unnecessarily complicated roll
Supported Operators
- Arithmetic:
+
-
*
/
%
^
()
(addition, subtraction, multiplication, division, modulus, exponent, parentheses) - Dice:
#d#
(eg,3d6
,d20
)- Rolls the left number of dice with the right number of sides.
3d6
rolls 3 six-sided dice - The first number is optional and defaults to 1 if omitted
- Rolls the left number of dice with the right number of sides.
- Dice modifiers:
- Keep/Drop Highest/Lowest:
kh#
kl#
dh#
dl#
- Keeps/Drops only the # highest/lowest dice rolls. Any that are either not kept or dropped are removed from the total
- The number is optional and defaults to 1 if omitted
- Exploding:
!
!#
!>#
!>=#
!<#
!<=#
- Each die that rolls maximum (
!
), or a specific number (!#
), or over/under a threshold (!>#
!>=#
!<#
!<=#
), adds an additional die to the pool- This repeats for each die added to the pool
- Each die that rolls maximum (
- Reroll:
r
r#
r>#
r>=#
r<#
r<=#
- Drops and rerolls each die that rolls minimum (
r
), or a specific number (r#
), or over/under a threshold (r>#
r>=#
r<#
r<=#
)- This repeats for each die rerolled. You can make it only reroll each die once with
ro
instead ofr
- This repeats for each die rerolled. You can make it only reroll each die once with
- Drops and rerolls each die that rolls minimum (
- Count:
c
c#
c>#
c>=#
c<#
c<=#
- Counts the number of dice that roll maximum (
c
), or a specific number (c#
), or over/under a threshold (c>#
c>=#
c<#
c<=#
)
- Counts the number of dice that roll maximum (
- Sorting:
s
sa
sd
- Sorts the dice rolls in ascending (
s
sa
) or descending (sd
) order - This still applies in non-verbose mode but you won't see any visible effect
- Sorts the dice rolls in ascending (
- Keep/Drop Highest/Lowest:
- Comments:
# your comment here
- Adds a comment to the end of the output, so you can describe what the roll is for. eg:
d20+5 # for initiative
- The
#
is a literal hash, not a number this time :)
- Adds a comment to the end of the output, so you can describe what the roll is for. eg:
If you have more ideas for operators, suggestions and pull requests are welcome!
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for pyhedrals-0.2.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 90ecbc1d352e7a459d4fb365bc3c7f097bf563f0573b56265361e50542b08948 |
|
MD5 | cc6f567cda9296418bc9976f3fe244d4 |
|
BLAKE2b-256 | 6017adefb957c1dcf39d2a0aab957adf439de9a0e63e71581f2f51294094736f |