我试图在 Python中实现Luhn 公式。这是我的代码:
import sys
def luhn_check(number):
if number.isdigit():
last_digit = int(str(number)[-1])
reverse_sequence = list(int(d) for d in str(int(number[-2::-1])))
for i in range(0, len(reverse_sequence), 2):
reverse_sequence[i] *= 2
for i in range(len(reverse_sequence)):
if reverse_sequence[i] > 9:
reverse_sequence[i] -= 9
sum_of_digits = 0
for i in range(len(reverse_sequence)):
sum_of_digits += reverse_sequence[i]
result = divmod(sum_of_digits, 10)
if result == last_digit:
print("[VALID] %s" % number)
else:
print("[INVALID] %s" % number)
quit()
print("[ERROR] \" %s \" is not a valid sequence." % number)
quit()
def main():
if len(sys.argv) < 2:
print("Usage: python TLF.py <sequence>")
quit()
luhn_check(sys.argv[1])
if __name__ == '__main__':
main()
但它不能正常工作:
[INVALID] 4532015112830366
[INVALID] 6011514433546201
[INVALID] 6771549495586802
等等...
但是代码的逻辑对我来说似乎没问题。我遵循了这个工作流程:
卢恩公式
删除数字的最后一位数字。最后一位数字是我们要检查的反转数字
将奇数位(1、3、5 等)的数字乘以 2,然后将所有大于 9 的结果减去 9
将所有数字加在一起
校验位(卡的最后一个数字)是您需要添加以获得 10 的倍数(模 10)的金额