Ошибка имени в кредите - pset6 CS50x - PullRequest
0 голосов
/ 15 апреля 2020

Я новичок в Python. Мой единственный фон в Python - CS50 (Неделя 6). Я пытаюсь реализовать кредит от pset6. В этом мы должны реализовать алгоритм Луна.

Но я получаю указанную ошибку и не могу понять, почему:

Traceback (most recent call last):
  File "credit.py", line 57, in <module>
    main()
  File "credit.py", line 9, in main
    if IfAmex(arr_number):
  File "credit.py", line 27, in IfAmex
    if Luhn(card_n):
  File "credit.py", line 50, in Luhn
    sum2 = sum(int(c) for c in str(2 * card_n[i]) for i in range(1, len(card_n), 2))
NameError: name 'i' is not defined

Вот мой код:

from sys import exit
from cs50 import get_int

def main():
    number = get_int("Number: ")
    # Converting the number into a list
    arr_number = [int(x) for x in str(number)]

    if IfAmex(arr_number):
        print("AMEX")
        exit(0)
    elif IfMasCard(arr_number):
        print("MASTERCARD")
        exit(0)
    elif IfVisa(arr_number):
        print("VISA")
        exit(0)
    else:
        print("INVALID")
        exit(0)

def IfAmex(card_n):
    if not len(card_n) == 15:
        return False
    if not (card_n[0] * 10 + card_n[1]) in [34, 37]:
        return False
    if Luhn(card_n):
        return True

def IfMasCas(card_n):
    if not len(card_n) == 16:
        return False
    if not (card_n[0] * 10 + card_n[1]) in range(51, 56):
        return False
    if Luhn(card_n):
        return True

def IfVisa(card_n):
    if not len(card_n) in [13, 16]:
        return False
    if not card_n[0] == 4:
        return False
    if Luhn(card_n):
        return True

def Luhn(card_n):
    # Reversing the digits
    card_n = card_n[::-1] 

    sum1 = sum(card_n[::2])
    sum2 = sum(int(c) for c in str(2 * card_n[i]) for i in range(1, len(card_n), 2)) # The Error Line

    luhnsum = sum1 + sum2

    return luhnsum % 10 == 0

if __name__ == '__main__':
    main()

И контрольный пример, который я использовал, был (вместе с правильным выводом):

$ python credit.py
Number: 378282246310005
AMEX

Также, скажите, пожалуйста, правильно ли я использую exit() или нет.

1 Ответ

0 голосов
/ 15 апреля 2020

Вы используете i здесь в качестве индекса массива card_n. Но вы забыли определить это.

Определите его и присвойте ему значение перед использованием.

sum2 = sum(int(c) for c in str(2 * card_n[i])

...