Python:重构代码以删除全局变量

时间:2013-08-25 18:31:22

标签: python refactoring global-variables

我目前在我的代码中使用名为correct的全局变量。考虑到全局变形是不受欢迎的,有没有更好的方法来设置我的代码来“保护”全局变量?

from random import randint
from random import choice

lower  = int(raw_input("Enter a lower integer constraint: "))
higher = int(raw_input("Enter a higher integer constraint: "))

correct = 0


def gen_randoms(lower, higher):
    integers = list()
    for x in xrange(4):
        rand_int = randint(lower, higher)
        integers.append(rand_int)
    return integers


def gen_equation(integers):
    nums = map(str, integers)
    operators = ['*', '+', '-']
    equation = 'num op num op num op num'
    while 'op' in equation:
        equation = equation.replace('op', choice(operators), 1)
    while 'num' in equation:
        equation = equation.replace('num', choice(nums), 1)
    print equation
    return equation


def evaluate(equation):
    answer = eval(equation)
    print answer
    return answer


def compare_answers(gen_answer, game):
    global correct
    user_answer = int(raw_input("What is the answer? "))
    if user_answer == gen_answer:
        correct += 1
        print 'Correct!'
        print 'Current streak: %s' % str(correct)
        game()
    else:
        print 'Incorrect!'
        correct = 0
        game()


def game():
    nums = gen_randoms(lower, higher)
    this_equation = gen_equation(nums)
    gen_answer = evaluate(this_equation)
    compare_answers(gen_answer, game)


game()

6 个答案:

答案 0 :(得分:3)

我可能会这样做:

#!/usr/bin/python

"""Equation solving game."""

from random import randint
from random import choice


def gen_randoms(lower, higher):

    """Generates four random numbers between provided bounds."""

    integers = [randint(lower, higher) for x in range(4)]
    return integers


def gen_equation(integers):

    """Generates a random equation from four provided integers."""

    nums = [str(i) for i in integers]
    operators = ['*', '+', '-']
    equation = 'num op num op num op num'
    while 'op' in equation:
        equation = equation.replace('op', choice(operators), 1)
    while 'num' in equation:
        equation = equation.replace('num', choice(nums), 1)
    return equation


def evaluate(equation):

    """Evaluates an equation."""

    return eval(equation)


def main():

    """Main game function."""

    lower = int(raw_input("Enter a lower integer constraint: "))
    higher = int(raw_input("Enter a higher integer constraint: "))
    nums = gen_randoms(lower, higher)
    streak = 0

    while True:
        this_equation = gen_equation(nums)
        print this_equation

        user_answer = raw_input("What is the answer? ('Q' to quit) ")

        if user_answer.lower()[0] == 'q':
            break

        gen_answer = evaluate(this_equation)
        print 'The answer was: %d' % gen_answer

        if gen_answer == int(user_answer):
            streak += 1
            print 'Correct!'
            print 'Current streak: %d' % streak
        else:
            streak = 0
            print 'Incorrect!'


if __name__ == "__main__":
    main()

一些评论:

  • 每个函数通常只应该做一件事,所以如果一个函数评估一个方程式,通常最好不要打印方程式。
  • 当你这样做时,弄清楚变量应该去哪里变得容易多了,因为当你需要将每个函数做几件不同的事情时,你不需要传递它们。
  • 这里的主要游戏逻辑非常简单,你真的不需要将它从你的主game()函数(或main()函数,在我的例子中)中分解出来,这么多,它没有'使事情过于复杂,让它留在那里。如果您想进行更多错误检查(例如,查看用户是否输入了无效的号码,并且您想要返回并要求提供更多输入,那么您可能想要将其分解更多。

答案 1 :(得分:1)

类似的东西:

def game(correct=0):    
    nums = gen_randoms(lower, higher)  
    this_equation = gen_equation(nums)  
    gen_answer = evaluate(this_equation)  
    correct = compare_answers(gen_answer, game, correct)  
    game(correct)  

答案 2 :(得分:0)

添加:

def game():
    correct = 0
    while True:
        nums = gen_randoms(lower, higher)
        this_equation = gen_equation(nums)
        gen_answer = evaluate(this_equation)
        user_answer = int(raw_input("What is the answer? "))
        if user_answer == gen_answer:
            correct += 1
            print 'Correct!'
            print 'Current streak: %s' % str(correct)
        else:
            print 'Incorrect!'
            correct = 0

然后删除这些旧代码:game()compare_answers()和全局变量correct

答案 3 :(得分:0)

  1. global correct
  2. 中删除compare_answers
  3. 设置game以使用默认值correct接收关键字参数0def game(correct =0)
  4. 设置compare_answers以获取第三个参数correct
  5. game compare_answers传递correct时传递def compare_answers(gen_answer, game, correct): user_answer = int(raw_input("What is the answer? ")) if user_answer == gen_answer: correct += 1 print 'Correct!' print 'Current streak: %s' % str(correct) game(correct) else: print 'Incorrect!' correct = 0 game(correct) def game(correct = 0): nums = gen_randoms(lower, higher) this_equation = gen_equation(nums) gen_answer = evaluate(this_equation) compare_answers(gen_answer, game, correct) game()
  6. <强>即:

    {{1}}

答案 4 :(得分:0)

我最终接受了@ JoelCornett的建议并创建了一个课程:

from random import randint
from random import choice

class Math_Problem_Generator(object):

    def __init__(self):
        self.lower = int(raw_input("Enter a lower integer constraint: "))
        self.higher = int(raw_input("Enter a higher integer constraint: "))
        self.correct = 0
        self.game(self.correct)


    def gen_randoms(self, lower, higher):
        integers = list()
        for x in xrange(4):
            rand_int = randint(lower, higher)
            integers.append(rand_int)
        return integers


    def gen_equation(self, integers):
        nums = map(str, integers)
        operators = ['*', '+', '-']
        equation = 'num op num op num op num'
        while 'op' in equation:
            equation = equation.replace('op', choice(operators), 1)
        while 'num' in equation:
            equation = equation.replace('num', choice(nums), 1)
        print equation
        return equation


    def evaluate(self, equation):
        answer = eval(equation)
        print answer
        return answer


    def compare_answers(self, gen_answer):
        user_answer = int(raw_input("What is the answer? "))
        if user_answer == gen_answer:
            self.correct += 1
            print 'Correct!'
            print 'Current streak: %s' % str(self.correct)
            self.game(self.correct)
        else:
            print 'Incorrect!'
            self.correct = 0
            self.game(self.correct)


    def game(self, correct):
        nums = self.gen_randoms(self.lower, self.higher)
        this_equation = self.gen_equation(nums)
        gen_answer = self.evaluate(this_equation)
        self.compare_answers(gen_answer)
        self.game()


Math_Problem_Generator()

答案 5 :(得分:0)

在调用者中收集结果,然后打印计数。这个版本摆脱了你的其他全局变量lowerhigher

def compare_answers(gen_answer):
    user_answer = int(raw_input("What is the answer? "))
    return user_anser == gen_answer

def game():

    correct = 0
    play_again = 'Y'

    while play_again.lower() == 'y':
        lower  = int(raw_input("Enter a lower integer constraint: "))
        higher = int(raw_input("Enter a higher integer constraint: "))
        nums = gen_randoms(lower, higher)
        this_equation = gen_equation(nums)
        gen_answer = evaluate(this_equation)
        if compare_answers(gen_answer):
           correct += 1
           print('You were right! Your winning streak is {0}'.format(correct))
        else:
           print('Sorry, your answer was wrong. :(')
           correct = 0

        play_again = raw_input('Would you like to play again? (Y/N): ')