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.0.7.tar.gz (5.6 kB view details)

Uploaded Source

File details

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

File metadata

  • Download URL: playingcards1598-1.0.7.tar.gz
  • Upload date:
  • Size: 5.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.0 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.0

File hashes

Hashes for playingcards1598-1.0.7.tar.gz
Algorithm Hash digest
SHA256 de1cec1ed15205dbff05ae53837d7bac42b6cf59ea01c1722d99856128612acc
MD5 1756eab38930593a3411e85e7c37b6d0
BLAKE2b-256 29ad931aebfff8575b863f3c82a518d5844df730cb7e3d8b0a13e9f72690102c

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