Yu-Gi-Oh cards in Python 3












1












$begingroup$


Problem



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.



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$

















    1












    $begingroup$


    Problem



    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.



    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$















      1












      1








      1





      $begingroup$


      Problem



      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.



      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$




      Problem



      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.



      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-3.x playing-cards






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited 7 mins ago









      Emma

      154213




      154213










      asked 17 mins ago









      Jerry CuiJerry Cui

      589




      589






















          0






          active

          oldest

          votes












          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

























          0






          active

          oldest

          votes








          0






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes
















          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

          Create new schema in PostgreSQL using DBeaver

          Deepest pit of an array with Javascript: test on Codility

          Fotorealismo