Skip to main content

An Advanced and Customisable Python Playing Card Module that makes creating playing card games and running simulations general, simple and easy!

Project description

playingcards.py

An Advanced and Customisable Python Playing Card Module that makes creating playing card games and running simulations general, simple and easy!

Features

  • Easy to use python interface
  • Easy to Understand, general, Class Objects
  • Card Comparisons

Installation

Requires Python 3.9 and above

You can install the module from PyPI or by using pip.

# Linux/MacOS
pip3 install playingcards1598

# Windows
pip install playingcards1598

How To Use

Quick Start

To quickly get started you can initiate a deck

from playingcards import Deck

deck = Deck()

Shuffle the deck using shuffle()

deck.shuffle()

Draw cards from this deck by using draw_top_n()

drawn_cards = deck.draw_top_n(5)  # Draws 5 cards

print(len(deck))  # Prints 47
print(len(drawn_cards))  # Prints 5

Return the deck to original form using reset()

deck.reset()
print(len(deck))  # Prints 52

Customization

Custom Cards

This module presents three class objects for creating custom cards: Rank and Suit for the building blocks, and Card for the construction.

You can construct custom classes as follows

rank = Rank('J', num_value=11)  # Creates a Jack rank
suit = Suit('s', pretty='â™ ')  # Creates a spade suit

card = Card(rank, suit)  # Creates the Jack of Hearts

A full deck of custom cards can be created by passing it during the Deck initiation.

custom_deck = Deck([card])  # A custom deck consisting of only the card the specified above

Alternatively, a custom deck can be instantiated using the from_ranks_suits() class method

big_red_deck = Deck.from_ranks_suits(
  [Rank(value, num) for rank, num in [('A', 14), ('K', 13), ('Q', 12), ('J', 11), ('T', 10)]],
  [Suit(suit, pretty) for suit, pretty in [('h', '♥'), ('d', '♦')]]
)

Card Collections

Deck is a subclass of CardCollection

Other CardCollection's are possible. For example, to create a Texas Holdem Poker hand (two cards), you could do the following

class TexasHand(CardCollection):
    def __init__(self, cards: list[Card]):
        super().__init__(cards, maximum = 2)

Class Arguments

  • Rank Arguments

    • value str - A string representation of the value of the rank
    • num_value int (optional) - A numerical value of the card, used in games that consist of ordering
  • Suit Arguments

    • value str - The desired value of the suit - s, h, c, d for a standard deck
    • pretty str (optional) - A prettier representation of the suit - â™ , ♥, ♣, ♦ for a standard deck
  • Card Arguments

    • rank Rank - The rank of the card
    • suit Suit - The suit of the card
  • Deck and CardCollection Arguments

    • cards list - A list of the cards in the collection
    • maximum int (optional) - The maximum number of cards in the collection

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

playingcards1598-1.2.5.tar.gz (7.7 kB view details)

Uploaded Source

File details

Details for the file playingcards1598-1.2.5.tar.gz.

File metadata

  • Download URL: playingcards1598-1.2.5.tar.gz
  • Upload date:
  • Size: 7.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.12.0

File hashes

Hashes for playingcards1598-1.2.5.tar.gz
Algorithm Hash digest
SHA256 1ebccf38d378f43590a0add48000a864253d772f9d1cff768d94daba28a21944
MD5 dbf6bb8472431db974d31e0d031a0b6b
BLAKE2b-256 7e7bd54e51d6c55d7bdf84bd4c83d43bb71f277b01bb55342ca972ae9370b4c6

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