Yu-Gi-Oh cards in Python 3 The Next CEO of Stack OverflowGenerating playing cardsASCII-fication of playing cardsFunction for shuffling cardsDynamic class instancing (with conditional parameters and methods) based on a dictionaryMy first finished Python program: a deck of cardsDeck of cards designMaking a deck of cards in PythonPoker Hand classifer part 3: Deck Object and 7 Card HandSimple Deck of Cards Python ProgramDeal three Poker hands of five cards each in Python

Why the difference in type-inference over the as-pattern in two similar function definitions?

Why isn't the Mueller report being released completely and unredacted?

Why doesn't UK go for the same deal Japan has with EU to resolve Brexit?

Why is information "lost" when it got into a black hole?

Domestic-to-international connection at Orlando (MCO)

Legal workarounds for testamentary trust perceived as unfair

What connection does MS Office have to Netscape Navigator?

Reference request: Grassmannian and Plucker coordinates in type B, C, D

How I can get glyphs from a fraktur font and use them as identifiers?

Why is the US ranked as #45 in Press Freedom ratings, despite its extremely permissive free speech laws?

Does Germany produce more waste than the US?

Do I need to write [sic] when a number is less than 10 but isn't written out?

How to delete every two lines after 3rd lines in a file contains very large number of lines?

If Nick Fury and Coulson already knew about aliens (Kree and Skrull) why did they wait until Thor's appearance to start making weapons?

Prepend last line of stdin to entire stdin

Can MTA send mail via a relay without being told so?

Is wanting to ask what to write an indication that you need to change your story?

Proper way to express "He disappeared them"

Is there a way to save my career from absolute disaster?

How is this set of matrices closed under multiplication?

Break Away Valves for Launch

A small doubt about the dominated convergence theorem

Bartok - Syncopation (1): Meaning of notes in between Grand Staff

Why isn't acceleration always zero whenever velocity is zero, such as the moment a ball bounces off a wall?



Yu-Gi-Oh cards in Python 3



The Next CEO of Stack OverflowGenerating playing cardsASCII-fication of playing cardsFunction for shuffling cardsDynamic class instancing (with conditional parameters and methods) based on a dictionaryMy first finished Python program: a deck of cardsDeck of cards designMaking a deck of cards in PythonPoker Hand classifer part 3: Deck Object and 7 Card HandSimple Deck of Cards Python ProgramDeal three Poker hands of five cards each in Python










4












$begingroup$


I made a project in Python 3.7.1 that includes classes to create Yu-Gi-Oh cards. This isn't the entire game; it is just the cards itself. I will create the entire game later. I want feedback on how to improve my code.



class Deck(object):
def __init__(self, main_deck):
self.main_deck = main_deck

def add_normal_cards(self, card_to_add, all_cards):
"""
Add monsters, spells and traps to the deck.
"""
if len(self.main_deck) > 60:
return "You have to many cards in your deck (60)."
else:
card_counter = 0
# Check to see how many copies of a card there are in your deck. Maximum 3 of the same card. Limited cards
# will be added eventually.
for card in self.main_deck:
if card == card_to_add:
card_counter += 1
if card_counter == 3:
return "You have to many copies of that card in your deck (3)."
else:
if card_to_add not in all_cards:
return "That card hasn't been added to the game yet (" + card_to_add + ")."
else:
self.main_deck.append(card_to_add)

def add_extra_cards(self, card_to_add, all_cards):
"""
Add monsters, spells and traps to the deck.
"""
if len(self.main_deck) > 15:
return "You have to many cards in your extra deck (15)."
else:
card_counter = 0
# Check to see how many copies of a card there are in your deck. Maximum 3 of the same card. Limited cards
# will be added eventually.
for card in self.main_deck:
if card == card_to_add:
card_counter += 1
if card_counter == 3:
return "You have to many copies of that card in your deck (3)."
else:
if card_to_add not in all_cards:
return "That card hasn't been added to the game yet (" + card_to_add + ")."
else:
self.main_deck.append(card_to_add)


class Monster(object):
def __init__(self, name, effects, attributes, monster_type, atk, _def, description):
self.name = name
self.effects = effects
self.attributes = attributes
self.type = monster_type
self.atk = atk
self._def = _def
self.description = description

def effect(self):
"""
Activate the effect of this monster.
"""
for effect in self.effects:
eval(effect)


class Spell(object):
def __init__(self, name, effects):
self.name = name
self.effects = effects

def activate(self):
"""
Activate the effect of this spell.
"""
for effect in self.effects:
eval(effect)


class Trap(object):
def __init__(self, name, effects):
self.name = name
self.effects = effects

def activate(self):
"""
Activate the effect of this spell.
"""
for effect in self.effects:
eval(effect)


class LinkMonster(object):
def __init__(self, name, effects, attributes, monster_type, atk, link_rating, description, recipe, links):
self.name = name
self.effects = effects
self.attributes = attributes
self.type = monster_type
self.atk = atk
self.link_rating = link_rating
self.description = description
self.recipe = recipe
self.links = links

def activate(self):
"""
Activate the effect of this monster.
"""
for effect in self.effects:
eval(effect)


class SynchroMonster(object):
def __init__(self, name, effects, attributes, monster_type, atk, _def, description, recipe):
self.name = name
self.effects = effects
self.attributes = attributes
self.type = monster_type
self.atk = atk
self._def = _def
self.description = description
self.recipe = recipe

def activate(self):
"""
Activate the effect of this monster.
"""
for effect in self.effects:
eval(effect)


class XyzMonster(object):
def __init__(self, name, effects, attributes, monster_type, atk, _def, description, recipe):
self.name = name
self.effects = effects
self.attributes = attributes
self.type = monster_type
self.atk = atk
self._def = _def
self.description = description
self.recipe = recipe
self.materials = recipe

def activate(self):
"""
Activate the effect of this monster.
"""
for effect in self.effects:
eval(effect)


class FusionMonster(object):
def __init__(self, name, effects, attributes, monster_type, atk, _def, description, recipe):
self.name = name
self.effects = effects
self.attributes = attributes
self.type = monster_type
self.atk = atk
self._def = _def
self.description = description
self.recipe = recipe

def activate(self):
"""
Activate the effect of this monster.
"""
for effect in self.effects:
eval(effect)


class PendulumMonster(object):
def __init__(self, name, effects, pendulum_effects, pendulum_scale, attributes, monster_type, atk, _def,
description, recipe):
self.name = name
self.effects = effects
self.pendulum_effects = pendulum_effects
self.pendulum_scale = pendulum_scale
self.attributes = attributes
self.type = monster_type
self.atk = atk
self._def = _def
self.description = description
self.recipe = recipe
self.materials = recipe

def activate(self):
"""
Activate the effect of this monster.
"""
for effect in self.effects:
eval(effect)

def pendulum_activate(self):
"""
Activate the effect of this monster while in Spell/Trap Zone.
"""
for effect in self.pendulum_effects:
eval(effect)









share|improve this question











$endgroup$
















    4












    $begingroup$


    I made a project in Python 3.7.1 that includes classes to create Yu-Gi-Oh cards. This isn't the entire game; it is just the cards itself. I will create the entire game later. I want feedback on how to improve my code.



    class Deck(object):
    def __init__(self, main_deck):
    self.main_deck = main_deck

    def add_normal_cards(self, card_to_add, all_cards):
    """
    Add monsters, spells and traps to the deck.
    """
    if len(self.main_deck) > 60:
    return "You have to many cards in your deck (60)."
    else:
    card_counter = 0
    # Check to see how many copies of a card there are in your deck. Maximum 3 of the same card. Limited cards
    # will be added eventually.
    for card in self.main_deck:
    if card == card_to_add:
    card_counter += 1
    if card_counter == 3:
    return "You have to many copies of that card in your deck (3)."
    else:
    if card_to_add not in all_cards:
    return "That card hasn't been added to the game yet (" + card_to_add + ")."
    else:
    self.main_deck.append(card_to_add)

    def add_extra_cards(self, card_to_add, all_cards):
    """
    Add monsters, spells and traps to the deck.
    """
    if len(self.main_deck) > 15:
    return "You have to many cards in your extra deck (15)."
    else:
    card_counter = 0
    # Check to see how many copies of a card there are in your deck. Maximum 3 of the same card. Limited cards
    # will be added eventually.
    for card in self.main_deck:
    if card == card_to_add:
    card_counter += 1
    if card_counter == 3:
    return "You have to many copies of that card in your deck (3)."
    else:
    if card_to_add not in all_cards:
    return "That card hasn't been added to the game yet (" + card_to_add + ")."
    else:
    self.main_deck.append(card_to_add)


    class Monster(object):
    def __init__(self, name, effects, attributes, monster_type, atk, _def, description):
    self.name = name
    self.effects = effects
    self.attributes = attributes
    self.type = monster_type
    self.atk = atk
    self._def = _def
    self.description = description

    def effect(self):
    """
    Activate the effect of this monster.
    """
    for effect in self.effects:
    eval(effect)


    class Spell(object):
    def __init__(self, name, effects):
    self.name = name
    self.effects = effects

    def activate(self):
    """
    Activate the effect of this spell.
    """
    for effect in self.effects:
    eval(effect)


    class Trap(object):
    def __init__(self, name, effects):
    self.name = name
    self.effects = effects

    def activate(self):
    """
    Activate the effect of this spell.
    """
    for effect in self.effects:
    eval(effect)


    class LinkMonster(object):
    def __init__(self, name, effects, attributes, monster_type, atk, link_rating, description, recipe, links):
    self.name = name
    self.effects = effects
    self.attributes = attributes
    self.type = monster_type
    self.atk = atk
    self.link_rating = link_rating
    self.description = description
    self.recipe = recipe
    self.links = links

    def activate(self):
    """
    Activate the effect of this monster.
    """
    for effect in self.effects:
    eval(effect)


    class SynchroMonster(object):
    def __init__(self, name, effects, attributes, monster_type, atk, _def, description, recipe):
    self.name = name
    self.effects = effects
    self.attributes = attributes
    self.type = monster_type
    self.atk = atk
    self._def = _def
    self.description = description
    self.recipe = recipe

    def activate(self):
    """
    Activate the effect of this monster.
    """
    for effect in self.effects:
    eval(effect)


    class XyzMonster(object):
    def __init__(self, name, effects, attributes, monster_type, atk, _def, description, recipe):
    self.name = name
    self.effects = effects
    self.attributes = attributes
    self.type = monster_type
    self.atk = atk
    self._def = _def
    self.description = description
    self.recipe = recipe
    self.materials = recipe

    def activate(self):
    """
    Activate the effect of this monster.
    """
    for effect in self.effects:
    eval(effect)


    class FusionMonster(object):
    def __init__(self, name, effects, attributes, monster_type, atk, _def, description, recipe):
    self.name = name
    self.effects = effects
    self.attributes = attributes
    self.type = monster_type
    self.atk = atk
    self._def = _def
    self.description = description
    self.recipe = recipe

    def activate(self):
    """
    Activate the effect of this monster.
    """
    for effect in self.effects:
    eval(effect)


    class PendulumMonster(object):
    def __init__(self, name, effects, pendulum_effects, pendulum_scale, attributes, monster_type, atk, _def,
    description, recipe):
    self.name = name
    self.effects = effects
    self.pendulum_effects = pendulum_effects
    self.pendulum_scale = pendulum_scale
    self.attributes = attributes
    self.type = monster_type
    self.atk = atk
    self._def = _def
    self.description = description
    self.recipe = recipe
    self.materials = recipe

    def activate(self):
    """
    Activate the effect of this monster.
    """
    for effect in self.effects:
    eval(effect)

    def pendulum_activate(self):
    """
    Activate the effect of this monster while in Spell/Trap Zone.
    """
    for effect in self.pendulum_effects:
    eval(effect)









    share|improve this question











    $endgroup$














      4












      4








      4





      $begingroup$


      I made a project in Python 3.7.1 that includes classes to create Yu-Gi-Oh cards. This isn't the entire game; it is just the cards itself. I will create the entire game later. I want feedback on how to improve my code.



      class Deck(object):
      def __init__(self, main_deck):
      self.main_deck = main_deck

      def add_normal_cards(self, card_to_add, all_cards):
      """
      Add monsters, spells and traps to the deck.
      """
      if len(self.main_deck) > 60:
      return "You have to many cards in your deck (60)."
      else:
      card_counter = 0
      # Check to see how many copies of a card there are in your deck. Maximum 3 of the same card. Limited cards
      # will be added eventually.
      for card in self.main_deck:
      if card == card_to_add:
      card_counter += 1
      if card_counter == 3:
      return "You have to many copies of that card in your deck (3)."
      else:
      if card_to_add not in all_cards:
      return "That card hasn't been added to the game yet (" + card_to_add + ")."
      else:
      self.main_deck.append(card_to_add)

      def add_extra_cards(self, card_to_add, all_cards):
      """
      Add monsters, spells and traps to the deck.
      """
      if len(self.main_deck) > 15:
      return "You have to many cards in your extra deck (15)."
      else:
      card_counter = 0
      # Check to see how many copies of a card there are in your deck. Maximum 3 of the same card. Limited cards
      # will be added eventually.
      for card in self.main_deck:
      if card == card_to_add:
      card_counter += 1
      if card_counter == 3:
      return "You have to many copies of that card in your deck (3)."
      else:
      if card_to_add not in all_cards:
      return "That card hasn't been added to the game yet (" + card_to_add + ")."
      else:
      self.main_deck.append(card_to_add)


      class Monster(object):
      def __init__(self, name, effects, attributes, monster_type, atk, _def, description):
      self.name = name
      self.effects = effects
      self.attributes = attributes
      self.type = monster_type
      self.atk = atk
      self._def = _def
      self.description = description

      def effect(self):
      """
      Activate the effect of this monster.
      """
      for effect in self.effects:
      eval(effect)


      class Spell(object):
      def __init__(self, name, effects):
      self.name = name
      self.effects = effects

      def activate(self):
      """
      Activate the effect of this spell.
      """
      for effect in self.effects:
      eval(effect)


      class Trap(object):
      def __init__(self, name, effects):
      self.name = name
      self.effects = effects

      def activate(self):
      """
      Activate the effect of this spell.
      """
      for effect in self.effects:
      eval(effect)


      class LinkMonster(object):
      def __init__(self, name, effects, attributes, monster_type, atk, link_rating, description, recipe, links):
      self.name = name
      self.effects = effects
      self.attributes = attributes
      self.type = monster_type
      self.atk = atk
      self.link_rating = link_rating
      self.description = description
      self.recipe = recipe
      self.links = links

      def activate(self):
      """
      Activate the effect of this monster.
      """
      for effect in self.effects:
      eval(effect)


      class SynchroMonster(object):
      def __init__(self, name, effects, attributes, monster_type, atk, _def, description, recipe):
      self.name = name
      self.effects = effects
      self.attributes = attributes
      self.type = monster_type
      self.atk = atk
      self._def = _def
      self.description = description
      self.recipe = recipe

      def activate(self):
      """
      Activate the effect of this monster.
      """
      for effect in self.effects:
      eval(effect)


      class XyzMonster(object):
      def __init__(self, name, effects, attributes, monster_type, atk, _def, description, recipe):
      self.name = name
      self.effects = effects
      self.attributes = attributes
      self.type = monster_type
      self.atk = atk
      self._def = _def
      self.description = description
      self.recipe = recipe
      self.materials = recipe

      def activate(self):
      """
      Activate the effect of this monster.
      """
      for effect in self.effects:
      eval(effect)


      class FusionMonster(object):
      def __init__(self, name, effects, attributes, monster_type, atk, _def, description, recipe):
      self.name = name
      self.effects = effects
      self.attributes = attributes
      self.type = monster_type
      self.atk = atk
      self._def = _def
      self.description = description
      self.recipe = recipe

      def activate(self):
      """
      Activate the effect of this monster.
      """
      for effect in self.effects:
      eval(effect)


      class PendulumMonster(object):
      def __init__(self, name, effects, pendulum_effects, pendulum_scale, attributes, monster_type, atk, _def,
      description, recipe):
      self.name = name
      self.effects = effects
      self.pendulum_effects = pendulum_effects
      self.pendulum_scale = pendulum_scale
      self.attributes = attributes
      self.type = monster_type
      self.atk = atk
      self._def = _def
      self.description = description
      self.recipe = recipe
      self.materials = recipe

      def activate(self):
      """
      Activate the effect of this monster.
      """
      for effect in self.effects:
      eval(effect)

      def pendulum_activate(self):
      """
      Activate the effect of this monster while in Spell/Trap Zone.
      """
      for effect in self.pendulum_effects:
      eval(effect)









      share|improve this question











      $endgroup$




      I made a project in Python 3.7.1 that includes classes to create Yu-Gi-Oh cards. This isn't the entire game; it is just the cards itself. I will create the entire game later. I want feedback on how to improve my code.



      class Deck(object):
      def __init__(self, main_deck):
      self.main_deck = main_deck

      def add_normal_cards(self, card_to_add, all_cards):
      """
      Add monsters, spells and traps to the deck.
      """
      if len(self.main_deck) > 60:
      return "You have to many cards in your deck (60)."
      else:
      card_counter = 0
      # Check to see how many copies of a card there are in your deck. Maximum 3 of the same card. Limited cards
      # will be added eventually.
      for card in self.main_deck:
      if card == card_to_add:
      card_counter += 1
      if card_counter == 3:
      return "You have to many copies of that card in your deck (3)."
      else:
      if card_to_add not in all_cards:
      return "That card hasn't been added to the game yet (" + card_to_add + ")."
      else:
      self.main_deck.append(card_to_add)

      def add_extra_cards(self, card_to_add, all_cards):
      """
      Add monsters, spells and traps to the deck.
      """
      if len(self.main_deck) > 15:
      return "You have to many cards in your extra deck (15)."
      else:
      card_counter = 0
      # Check to see how many copies of a card there are in your deck. Maximum 3 of the same card. Limited cards
      # will be added eventually.
      for card in self.main_deck:
      if card == card_to_add:
      card_counter += 1
      if card_counter == 3:
      return "You have to many copies of that card in your deck (3)."
      else:
      if card_to_add not in all_cards:
      return "That card hasn't been added to the game yet (" + card_to_add + ")."
      else:
      self.main_deck.append(card_to_add)


      class Monster(object):
      def __init__(self, name, effects, attributes, monster_type, atk, _def, description):
      self.name = name
      self.effects = effects
      self.attributes = attributes
      self.type = monster_type
      self.atk = atk
      self._def = _def
      self.description = description

      def effect(self):
      """
      Activate the effect of this monster.
      """
      for effect in self.effects:
      eval(effect)


      class Spell(object):
      def __init__(self, name, effects):
      self.name = name
      self.effects = effects

      def activate(self):
      """
      Activate the effect of this spell.
      """
      for effect in self.effects:
      eval(effect)


      class Trap(object):
      def __init__(self, name, effects):
      self.name = name
      self.effects = effects

      def activate(self):
      """
      Activate the effect of this spell.
      """
      for effect in self.effects:
      eval(effect)


      class LinkMonster(object):
      def __init__(self, name, effects, attributes, monster_type, atk, link_rating, description, recipe, links):
      self.name = name
      self.effects = effects
      self.attributes = attributes
      self.type = monster_type
      self.atk = atk
      self.link_rating = link_rating
      self.description = description
      self.recipe = recipe
      self.links = links

      def activate(self):
      """
      Activate the effect of this monster.
      """
      for effect in self.effects:
      eval(effect)


      class SynchroMonster(object):
      def __init__(self, name, effects, attributes, monster_type, atk, _def, description, recipe):
      self.name = name
      self.effects = effects
      self.attributes = attributes
      self.type = monster_type
      self.atk = atk
      self._def = _def
      self.description = description
      self.recipe = recipe

      def activate(self):
      """
      Activate the effect of this monster.
      """
      for effect in self.effects:
      eval(effect)


      class XyzMonster(object):
      def __init__(self, name, effects, attributes, monster_type, atk, _def, description, recipe):
      self.name = name
      self.effects = effects
      self.attributes = attributes
      self.type = monster_type
      self.atk = atk
      self._def = _def
      self.description = description
      self.recipe = recipe
      self.materials = recipe

      def activate(self):
      """
      Activate the effect of this monster.
      """
      for effect in self.effects:
      eval(effect)


      class FusionMonster(object):
      def __init__(self, name, effects, attributes, monster_type, atk, _def, description, recipe):
      self.name = name
      self.effects = effects
      self.attributes = attributes
      self.type = monster_type
      self.atk = atk
      self._def = _def
      self.description = description
      self.recipe = recipe

      def activate(self):
      """
      Activate the effect of this monster.
      """
      for effect in self.effects:
      eval(effect)


      class PendulumMonster(object):
      def __init__(self, name, effects, pendulum_effects, pendulum_scale, attributes, monster_type, atk, _def,
      description, recipe):
      self.name = name
      self.effects = effects
      self.pendulum_effects = pendulum_effects
      self.pendulum_scale = pendulum_scale
      self.attributes = attributes
      self.type = monster_type
      self.atk = atk
      self._def = _def
      self.description = description
      self.recipe = recipe
      self.materials = recipe

      def activate(self):
      """
      Activate the effect of this monster.
      """
      for effect in self.effects:
      eval(effect)

      def pendulum_activate(self):
      """
      Activate the effect of this monster while in Spell/Trap Zone.
      """
      for effect in self.pendulum_effects:
      eval(effect)






      python python-3.x playing-cards






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited 2 hours ago









      Jamal

      30.5k11121227




      30.5k11121227










      asked 3 hours ago









      Jerry CuiJerry Cui

      739




      739




















          2 Answers
          2






          active

          oldest

          votes


















          3












          $begingroup$

          • I know you're trying to abbreviate "defense," but you could consider writing the whole thing out instead of making inconsistent naming with the preceding underscore. As such, you could write out "attack" as well to keep it more consistent.

          • Perhaps all those monster classes should be consolidates somehow. There are a lot of repeated self statements and similar functions, making the code harder to follow and likely maintain.


          • The 60, 15, and 3 are "magic numbers" (numbers without some kind of given context), and from where they are, they could be harder to maintain.



            Although Python doesn't actual constants like other languages, you can still do something similar above the functions:



            MAX_DECK_CARDS = 60




            MAX_EXTRA_CARDS = 15




            MAX_EXTRA_CARDS = 3



          • There's a grammatical error here:




            "You have to many copies of that card in your deck (3)."



            It should be "too" instead of "to."




          • When incrementing by 1:




            card_counter += 1



            You can just use the ++ operator:



            card_counter++






          share|improve this answer









          $endgroup$








          • 1




            $begingroup$
            Yes to everything except ++. That isn't a thing in Python. Please remove it.
            $endgroup$
            – Reinderien
            1 hour ago


















          3












          $begingroup$

          Trim redundant else



          ...here:



          if len(self.main_deck) > 60:
          return "You have to many cards in your deck (60)."
          else:


          The else isn't needed because you've already returned. This pattern happens in a few places.



          Lose some loops



          This:



           card_counter = 0
          for card in self.main_deck:
          if card == card_to_add:
          card_counter += 1


          can be



          card_counter = sum(1 for card in self.main_deck if card == card_to_add)


          However, that exposes a larger issue - you shouldn't be keeping copies of the same card value in your deck data structure. Instead, consider something like a dictionary, whose keys are the card names, and the values are card counts. That would really simplify much of your code.



          Don't eval



          Just don't. There's never a good reason. Make effects an iterable of functions, and simply call them.






          share|improve this answer









          $endgroup$













            Your Answer





            StackExchange.ifUsing("editor", function ()
            return StackExchange.using("mathjaxEditing", function ()
            StackExchange.MarkdownEditor.creationCallbacks.add(function (editor, postfix)
            StackExchange.mathjaxEditing.prepareWmdForMathJax(editor, postfix, [["\$", "\$"]]);
            );
            );
            , "mathjax-editing");

            StackExchange.ifUsing("editor", function ()
            StackExchange.using("externalEditor", function ()
            StackExchange.using("snippets", function ()
            StackExchange.snippets.init();
            );
            );
            , "code-snippets");

            StackExchange.ready(function()
            var channelOptions =
            tags: "".split(" "),
            id: "196"
            ;
            initTagRenderer("".split(" "), "".split(" "), channelOptions);

            StackExchange.using("externalEditor", function()
            // Have to fire editor after snippets, if snippets enabled
            if (StackExchange.settings.snippets.snippetsEnabled)
            StackExchange.using("snippets", function()
            createEditor();
            );

            else
            createEditor();

            );

            function createEditor()
            StackExchange.prepareEditor(
            heartbeatType: 'answer',
            autoActivateHeartbeat: false,
            convertImagesToLinks: false,
            noModals: true,
            showLowRepImageUploadWarning: true,
            reputationToPostImages: null,
            bindNavPrevention: true,
            postfix: "",
            imageUploader:
            brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
            contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
            allowUrls: true
            ,
            onDemand: true,
            discardSelector: ".discard-answer"
            ,immediatelyShowMarkdownHelp:true
            );



            );













            draft saved

            draft discarded


















            StackExchange.ready(
            function ()
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fcodereview.stackexchange.com%2fquestions%2f216560%2fyu-gi-oh-cards-in-python-3%23new-answer', 'question_page');

            );

            Post as a guest















            Required, but never shown

























            2 Answers
            2






            active

            oldest

            votes








            2 Answers
            2






            active

            oldest

            votes









            active

            oldest

            votes






            active

            oldest

            votes









            3












            $begingroup$

            • I know you're trying to abbreviate "defense," but you could consider writing the whole thing out instead of making inconsistent naming with the preceding underscore. As such, you could write out "attack" as well to keep it more consistent.

            • Perhaps all those monster classes should be consolidates somehow. There are a lot of repeated self statements and similar functions, making the code harder to follow and likely maintain.


            • The 60, 15, and 3 are "magic numbers" (numbers without some kind of given context), and from where they are, they could be harder to maintain.



              Although Python doesn't actual constants like other languages, you can still do something similar above the functions:



              MAX_DECK_CARDS = 60




              MAX_EXTRA_CARDS = 15




              MAX_EXTRA_CARDS = 3



            • There's a grammatical error here:




              "You have to many copies of that card in your deck (3)."



              It should be "too" instead of "to."




            • When incrementing by 1:




              card_counter += 1



              You can just use the ++ operator:



              card_counter++






            share|improve this answer









            $endgroup$








            • 1




              $begingroup$
              Yes to everything except ++. That isn't a thing in Python. Please remove it.
              $endgroup$
              – Reinderien
              1 hour ago















            3












            $begingroup$

            • I know you're trying to abbreviate "defense," but you could consider writing the whole thing out instead of making inconsistent naming with the preceding underscore. As such, you could write out "attack" as well to keep it more consistent.

            • Perhaps all those monster classes should be consolidates somehow. There are a lot of repeated self statements and similar functions, making the code harder to follow and likely maintain.


            • The 60, 15, and 3 are "magic numbers" (numbers without some kind of given context), and from where they are, they could be harder to maintain.



              Although Python doesn't actual constants like other languages, you can still do something similar above the functions:



              MAX_DECK_CARDS = 60




              MAX_EXTRA_CARDS = 15




              MAX_EXTRA_CARDS = 3



            • There's a grammatical error here:




              "You have to many copies of that card in your deck (3)."



              It should be "too" instead of "to."




            • When incrementing by 1:




              card_counter += 1



              You can just use the ++ operator:



              card_counter++






            share|improve this answer









            $endgroup$








            • 1




              $begingroup$
              Yes to everything except ++. That isn't a thing in Python. Please remove it.
              $endgroup$
              – Reinderien
              1 hour ago













            3












            3








            3





            $begingroup$

            • I know you're trying to abbreviate "defense," but you could consider writing the whole thing out instead of making inconsistent naming with the preceding underscore. As such, you could write out "attack" as well to keep it more consistent.

            • Perhaps all those monster classes should be consolidates somehow. There are a lot of repeated self statements and similar functions, making the code harder to follow and likely maintain.


            • The 60, 15, and 3 are "magic numbers" (numbers without some kind of given context), and from where they are, they could be harder to maintain.



              Although Python doesn't actual constants like other languages, you can still do something similar above the functions:



              MAX_DECK_CARDS = 60




              MAX_EXTRA_CARDS = 15




              MAX_EXTRA_CARDS = 3



            • There's a grammatical error here:




              "You have to many copies of that card in your deck (3)."



              It should be "too" instead of "to."




            • When incrementing by 1:




              card_counter += 1



              You can just use the ++ operator:



              card_counter++






            share|improve this answer









            $endgroup$



            • I know you're trying to abbreviate "defense," but you could consider writing the whole thing out instead of making inconsistent naming with the preceding underscore. As such, you could write out "attack" as well to keep it more consistent.

            • Perhaps all those monster classes should be consolidates somehow. There are a lot of repeated self statements and similar functions, making the code harder to follow and likely maintain.


            • The 60, 15, and 3 are "magic numbers" (numbers without some kind of given context), and from where they are, they could be harder to maintain.



              Although Python doesn't actual constants like other languages, you can still do something similar above the functions:



              MAX_DECK_CARDS = 60




              MAX_EXTRA_CARDS = 15




              MAX_EXTRA_CARDS = 3



            • There's a grammatical error here:




              "You have to many copies of that card in your deck (3)."



              It should be "too" instead of "to."




            • When incrementing by 1:




              card_counter += 1



              You can just use the ++ operator:



              card_counter++







            share|improve this answer












            share|improve this answer



            share|improve this answer










            answered 2 hours ago









            JamalJamal

            30.5k11121227




            30.5k11121227







            • 1




              $begingroup$
              Yes to everything except ++. That isn't a thing in Python. Please remove it.
              $endgroup$
              – Reinderien
              1 hour ago












            • 1




              $begingroup$
              Yes to everything except ++. That isn't a thing in Python. Please remove it.
              $endgroup$
              – Reinderien
              1 hour ago







            1




            1




            $begingroup$
            Yes to everything except ++. That isn't a thing in Python. Please remove it.
            $endgroup$
            – Reinderien
            1 hour ago




            $begingroup$
            Yes to everything except ++. That isn't a thing in Python. Please remove it.
            $endgroup$
            – Reinderien
            1 hour ago













            3












            $begingroup$

            Trim redundant else



            ...here:



            if len(self.main_deck) > 60:
            return "You have to many cards in your deck (60)."
            else:


            The else isn't needed because you've already returned. This pattern happens in a few places.



            Lose some loops



            This:



             card_counter = 0
            for card in self.main_deck:
            if card == card_to_add:
            card_counter += 1


            can be



            card_counter = sum(1 for card in self.main_deck if card == card_to_add)


            However, that exposes a larger issue - you shouldn't be keeping copies of the same card value in your deck data structure. Instead, consider something like a dictionary, whose keys are the card names, and the values are card counts. That would really simplify much of your code.



            Don't eval



            Just don't. There's never a good reason. Make effects an iterable of functions, and simply call them.






            share|improve this answer









            $endgroup$

















              3












              $begingroup$

              Trim redundant else



              ...here:



              if len(self.main_deck) > 60:
              return "You have to many cards in your deck (60)."
              else:


              The else isn't needed because you've already returned. This pattern happens in a few places.



              Lose some loops



              This:



               card_counter = 0
              for card in self.main_deck:
              if card == card_to_add:
              card_counter += 1


              can be



              card_counter = sum(1 for card in self.main_deck if card == card_to_add)


              However, that exposes a larger issue - you shouldn't be keeping copies of the same card value in your deck data structure. Instead, consider something like a dictionary, whose keys are the card names, and the values are card counts. That would really simplify much of your code.



              Don't eval



              Just don't. There's never a good reason. Make effects an iterable of functions, and simply call them.






              share|improve this answer









              $endgroup$















                3












                3








                3





                $begingroup$

                Trim redundant else



                ...here:



                if len(self.main_deck) > 60:
                return "You have to many cards in your deck (60)."
                else:


                The else isn't needed because you've already returned. This pattern happens in a few places.



                Lose some loops



                This:



                 card_counter = 0
                for card in self.main_deck:
                if card == card_to_add:
                card_counter += 1


                can be



                card_counter = sum(1 for card in self.main_deck if card == card_to_add)


                However, that exposes a larger issue - you shouldn't be keeping copies of the same card value in your deck data structure. Instead, consider something like a dictionary, whose keys are the card names, and the values are card counts. That would really simplify much of your code.



                Don't eval



                Just don't. There's never a good reason. Make effects an iterable of functions, and simply call them.






                share|improve this answer









                $endgroup$



                Trim redundant else



                ...here:



                if len(self.main_deck) > 60:
                return "You have to many cards in your deck (60)."
                else:


                The else isn't needed because you've already returned. This pattern happens in a few places.



                Lose some loops



                This:



                 card_counter = 0
                for card in self.main_deck:
                if card == card_to_add:
                card_counter += 1


                can be



                card_counter = sum(1 for card in self.main_deck if card == card_to_add)


                However, that exposes a larger issue - you shouldn't be keeping copies of the same card value in your deck data structure. Instead, consider something like a dictionary, whose keys are the card names, and the values are card counts. That would really simplify much of your code.



                Don't eval



                Just don't. There's never a good reason. Make effects an iterable of functions, and simply call them.







                share|improve this answer












                share|improve this answer



                share|improve this answer










                answered 58 mins ago









                ReinderienReinderien

                5,035925




                5,035925



























                    draft saved

                    draft discarded
















































                    Thanks for contributing an answer to Code Review Stack Exchange!


                    • Please be sure to answer the question. Provide details and share your research!

                    But avoid


                    • Asking for help, clarification, or responding to other answers.

                    • Making statements based on opinion; back them up with references or personal experience.

                    Use MathJax to format equations. MathJax reference.


                    To learn more, see our tips on writing great answers.




                    draft saved


                    draft discarded














                    StackExchange.ready(
                    function ()
                    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fcodereview.stackexchange.com%2fquestions%2f216560%2fyu-gi-oh-cards-in-python-3%23new-answer', 'question_page');

                    );

                    Post as a guest















                    Required, but never shown





















































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown

































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown







                    Popular posts from this blog

                    How should I use the fbox command correctly to avoid producing a Bad Box message?How to put a long piece of text in a box?How to specify height and width of fboxIs there an arrayrulecolor-like command to change the rule color of fbox?What is the command to highlight bad boxes in pdf?Why does fbox sometimes place the box *over* the graphic image?how to put the text in the boxHow to create command for a box where text inside the box can automatically adjust?how can I make an fbox like command with certain color, shape and width of border?how to use fbox in align modeFbox increase the spacing between the box and it content (inner margin)how to change the box height of an equationWhat is the use of the hbox in a newcommand command?

                    Tender dossier with centered articlesHow can I get legal style indentation on section, subsection, subsubsec.. using titlesec?missing item with addtocontents before sectionsubsubsubsection, paragraph and subparagraph count not reset when starting a new section, subsection, etcTikZ won't support HSB color model hsb in article document classAdding a vskip1em before each section - won't compile with itHow to implement a customized hierarchical table of content using titletoc with changing number formatsSection title formatGrouped entries in index don't spill over to next columnParagraph spacing in documentclassarticle with Figure and ListingsRagged Right Index Entries

                    Doxepinum Nexus interni Notae | Tabula navigationis3158DB01142WHOa682390"Structural Analysis of the Histamine H1 Receptor""Transdermal and Topical Drug Administration in the Treatment of Pain""Antidepressants as antipruritic agents: A review"