0

ゲームクラスの側で gettot() メソッドを動作させるのに問題があります。ゲーム全体で呼び出されると、関数が正しく動作するための正しい量の入力がないというエラーが返されます。現在、関数の最初の繰り返しはコメントアウトされているため、実行するたびにゲームを停止することなく、プロジェクトをさらに進めることができます。

これは、問題が発生している gettot メソッドです。


このメソッドの目的は、プレーヤーまたはディーラーが手札に持っているカードの合計を取得することです。エースがある場合、1 または 11 のどちらが 21 に近づくかによって、1 または 11 になるかどうかを決定します。オーバーせずに合計点。

def gettot(self,hand):
        total=0
        for x in self.hand:
            if x==Card('H','A'):
                b=total+x
                if b>21:
                    total+=1
                else:
                    total+=11
            if x==Card('D','A'):
                b=total+x
                if b>21:
                    total+=1
                else:
                    total+=11
            if x==Card('S','A'):
                b=total+x
                if b>21:
                    total+=1
                else:
                    total+=11
            if x==Card('C','A'):
                b=total+x #changed
                if b>21:
                    total+=1
                else:
                    total+=11
            else:
                total+=x
        return(total)

from random import*
#do we need to address anywhere that all face cards are worth 10?
class Card(object):
    def __init__(self,suit,number):
        self.number=number
        self.suit=suit
    def __str__(self):
        return '%s %s'%(self.number,self.suit)

class DeckofCards(object):
    def __init__(self,deck):
        self.deck=deck
        self.shuffledeck=self.shuffle()

    def shuffle(self):
        b=[]
        count=0
        while count<len(self.deck):
            a=randrange(0,len(self.deck))
            if a not in b:
                b.append(self.deck[a])
                count+=1
        return(b)

    def deal(self):
        if len(self.shuffledeck)>0:
            return(self.shuffledeck.pop(0))
        else:
            shuffle(self.deck) #need to refill deck
            return(self.shuffledeck.pop(0))
class Player(object):
    def __init__(self,name,hand,inout,money,score,bid):
        self.name=name
        self.hand=hand
        self.inout=inout
        self.money=money
        self.score=score
        self.bid=bid

    def __str__(self):
        x = self.name + ":\t"
        x += "Card(s):"
        for y in range(len(self.hand)):
            x +=self.hand[y].face + self.hand[y].suit + " "
        if (self.name != "dealer"):
            x += "\t Money: $" + str(self.money)
        return(x)

class Game(object):
    def __init__(self,deck, player):
        self.player=Player(player,[],True,100,0,0)
        self.dealer=Player("Dealer",[],True,100,0,0)
        self.deck=DeckofCards(deck)
        self.blackjack= False
    def blackjacksearch(self):
        if Game.gettot(self.player.hand)==21:#changed
            return True
        else:
            return False    
    def firstround(self):
        #self.player.inout=True#do we need this since this is above
        #self.player.hand=[]#do wee need this....
        #self.dealer.hand=[]#do we need this ....
        self.player.hand.append(DeckofCards.deal(self.deck))
        for card in self.player.hand:
            a=card
        print(self.player.name + ' ,you were dealt a '+str(a))
        self.dealer.hand.append(DeckofCards.deal(self.deck))
        for card in self.dealer.hand:
            a=card
        print('The Dealer has '+str(a))
        playerbid=int(input(self.player.name + ' how much would you like to bet? '))
        self.player.money-=playerbid
        self.player.bid=playerbid
    def playturn(self): #should this be changed to inout instead of hit.....we never use inout
        #for player in self.player:
        #    a=player
        #print(str(a))
        hit=input('Would you like to hit? ') #should input be in loop?
        while self.player.inout==True: #and self.blackjack!=True:#changed
            #print(self.player.name + ' , your hand has:' + str(self.player.hand)) #do we want to make this gettot? so it prints out the players total instead of a list....if we want it in a list we should print it with out brakets
            self.player.hand.append(DeckofCards.deal(self.deck))
            for card in self.player.hand:
                a=card
            print('The card that you just drew is: ' + str(a))            
            print(self.player.name + ' , your hand has:' + str([str(card) for card in self.player.hand]))
            #print(Game.gettot(self.player.hand)) 
            hit=input('Would you like to hit? ')
            if hit=='yes':
                (self.player.hand.append(DeckofCards.deal(self.deck)))#changed
                self.player.inout==True#
            else:
                (self.player.hand) #changed
                self.player.inout==False #changed
        if self.player.blackjack==True:
            print(self.player.name + " has blackjack ")
        if hit=='no':
            print (self.player.hand.gettot())
    def playdealer(self):
        while Game.gettot(self.dealer.hand)<17:#changed
            self.dealer.hand.append(DeckofCards.deal(self.deck))
            dealerhand=Game.gettot(self.dealer.hand) #changed
            print(dealerhand)
        if Game.gettot(self.dealer.hand)==21:#changed
            self.dealer.blackhjack=True
        dealerhand1=Game.gettot(self.dealer.hand)#changed
        print(dealerhand1)

    def gettot(self,hand):
        total=0
        for x in self.hand:
            if x==Card('H','A'):
                b=total+x
                if b>21:
                    total+=1
                else:
                    total+=11
            if x==Card('D','A'):
                b=total+x
                if b>21:
                    total+=1
                else:
                    total+=11
            if x==Card('S','A'):
                b=total+x
                if b>21:
                    total+=1
                else:
                    total+=11
            if x==Card('C','A'):
                b=total+x #changed
                if b>21:
                    total+=1
                else:
                    total+=11
            else:
                total+=x
        return(total)

    def playgame(self):
        play = "yes"
        while (play.lower() == "yes"):
            self.firstround()
            self.playturn()
            if self.player.blackjack == True:
                print(self.player.name + " got BLACKJACK! ")
                self.player.money += self.player.bid * 1.5
                print (self.player.name + " now has " + str(self.player.money))
                print("\n")
                self.player.inout = False
            if self.player.score > 21:
                print(self.player.name + " lost with a tot of " + str(self.player.score))
                self.player.money -= self.player.bid
                print (self.player.name + " now has " + str(self.player.money))
                print ("\n\n")
                self.player.inout = False
            self.playdealer()
            if self.dealer.blackjack == True:
                print("Dealer got blackjack, dealer wins\n")
                self.player.money -= self.player.bid
                print("Round\n")
                print("\t",self.dealer)
                print("\t",self.player)
                print("\t Dealer has " + str(self.dealer.score) + ", " + self.player.name + " has " + str(self.player.score))
            elif self.player.inout == True:
                print("Round\n")
                print("\t",self.dealer)
                print("\t",self.player)
                print("\n\t Dealer has " + str(self.dealer.score) + ", " + self.player.name + " has " + str(self.player.score))
                if self.dealer.score > 21:
                    print("\t Dealer lost with a total of " + str(self.dealer.score))
                    self.player.money += self.player.bid
                    print(self.player.name + " now has " + str(self.player.money))
                elif self.player.score > self.dealer.score:
                    print("\t" +self.player.name + " won with a total of " + str(self.player.score))
                    self.player.money += self.player.bid
                    print("\t"+self.player.name + " now has " + str(self.player.money))
                else:
                    print("\t Dealer won with a total of " + str(self.dealer.score))
                    self.player.money -= self.player.bid
                    print("\t"+self.player.name + " now has " + str(self.player.money))
            else:
                print("Round")
                print("\t",self.dealer)
                print("\t",self.player)
                if self.player.blackjack == False:
                    print("\t "+ self.player.name + " lost" )
                else:
                    print("\t "+self.player.name + " Won!")

            if self.player.money <= 0:
                print(self.player.name + " out of money - out of game ")
                play = "no"
            else:
                play = input("\nAnother round? ")
                print("\n\n")
        print("\nGame over. ")
        print(self.player.name + " ended with " + str(self.player.money) + " dollars.\n")
        print("Thanks for playing.  Come back soon!")



ls= [Card('H','A'),Card('H','2'),Card('H','3'),Card('H','4'),Card('H','5'),Card('H','6'),Card('H','7'),Card('H','8'),Card('H','9'),Card('H','10'),
Card('H','J'),Card('H','Q'),Card('H','K'),
Card('S','A'),Card('S','2'),Card('S','3'),Card('S','4'),Card('S','5'),
Card('S','6'),Card('S','7'),Card('S','8'),Card('S','9'),Card('S','10'),
Card('S','J'),Card('S','Q'),Card('S','K'),
Card('C','A'),Card('C','2'),Card('C','3'),Card('C','4'),Card('C','5'),
Card('C','6'),Card('C','7'),Card('C','8'),Card('C','9'),Card('C','10'),
Card('C','J'),Card('C','Q'),Card('C','K'),
Card('D','A'),Card('D','2'),Card('D','3'),Card('D','4'),Card('D','5'),
Card('D','6'),Card('D','7'),Card('D','8'),Card('D','9'),Card('D','10'),
Card('D','J'),Card('D','Q'),Card('D','K')]


def main():
    x = input("Player's name? ")
    blackjack = Game(ls,x)
    blackjack.playgame()
main()
4

3 に答える 3

2

TL;DR ですが、私が気づいたことが 1 つありますx==Card('H','A')

Card有用な方法で等価比較を処理するように型を定義しない限り、これは機能しません。デフォルトでは、両方が同じオブジェクトであるかどうかがチェックされ、新しいカードを作成すると、 と同じオブジェクトにはなりませんx

class Card(object):
    # ...
    def __eq__ (self, other):
        return self.number == other.number and self.suit == other.suit

また、これ: b=total+x. が Card オブジェクトの場合x、それが数値に追加されることをどのように想像しますか? これを定義するか、b = total + x.number代わりに行う必要があります。

もう 1 つのことはgettot、パラメーターを取るように定義することですhandが、関数では、 を反復処理しself.handます。そのため、関数に渡す他のハンドは静かに無視され、self.hand代わりに使用されます。

これも:

def blackjacksearch(self):
    if Game.gettot(self.player.hand)==21:
    # ...

このメソッドは Game タイプに属します。そしてそれはインスタンスメソッドです(パラメーターを取りselfます)。ただし、実際にGameは、インスタンスではなく型から静的メソッドとして呼び出します。代わりに次のようにする必要がありますself.gettot()(上記のようにパラメーターを省略できます)。

他の場所でも同じことを行い、 を使用してインスタンス メソッドを呼び出そうとしますTypeName.method。それらを呼び出すオブジェクトが必要です。

gettotメソッドをもっと短くすることもできると思います:

def gettot(self,hand):
    total=0
    for x in self.hand:
        if x.number == 'A':
            if total + 11 > 21:
                total += 1
            else:
                total += 11
        elif x.number == 'J' or x.number == 'Q' or x.number == 'K':
            pass # what to do with these?
        else:
            total += x.number
    return(total)

コードの一部を書き直す:

class Card (object):
    def __init__ (self, suit, number):
        self.suit = suit
        self.number = number

    def getValue (self):
        if self.number in ('J', 'Q', 'K'):
            return 10
        elif self.number == 'A':
            return 11
        else
            return int(self.number)

    def isAce (self):
        return self.number == 'A'

    def __eq__ (self, other):
        return self.suit == other.suit and self.number == other.number

    def __str__ (self):
        return '%s %s' % (self.number,self.suit)

class DeckOfCards (object):
    def __init__ (self, deck):
        self.fullDeck = deck
        self.shuffle()

    def shuffle (self):
        self.deck = self.fullDeck[:] # copy the full deck
        random.shuffle(self.deck)

    def deal (self):
        if not len(self.deck): # need to refill deck
            self.shuffle()
        return self.deck.pop(0)

ls = []
for suit in ('H', 'S', 'C', 'D'):
    for number in ('A', '2', '3', '4', '5', '6', '7', '8', '9', '10', 'J', 'Q', 'K'):
        ls.append(Card(suit, number))

メソッドgettotはプレーヤーに属している必要があり、次のようになります。

def gettot(self):
    total = 0
    for card in self.hand:
        if card.isAce() and total > 10:
            total += 1
        else:
            total += card.getValue()
    return total
于 2013-05-09T19:43:17.677 に答える