所以我有一个包含完整信用卡号的csv文件.我们不需要完整的号码,所以我正在编写一个快速脚本来解析csv并用掩码表示替换cc号.(除了最后四个之外所有*).我是python的新手,并将其破解,并且它可以工作,但为了学习我想知道它是否可以更轻松地完成.
假设"str"将是一个完整的信用卡号码.但是为了我的例子,我只使用字符串"CREDITCARDNUMBER".
str = "CREDITCARDNUMBER";
strlength = len(str)
masked = strlength - 4
slimstr = str[masked:]
print "*" * masked + slimstr
Run Code Online (Sandbox Code Playgroud)
输出正是我想要的
************MBER
Run Code Online (Sandbox Code Playgroud)
但我相信有更优雅的解决方案.:) 谢谢!
Kat*_*iel 14
Neater仍然:
>>> s = "CREDITCARDNUMBER"
>>> s[-4:].rjust(len(s), "*")
'************MBER'
Run Code Online (Sandbox Code Playgroud)
也许稍微优雅一点:
card = "CREDITCARDNUMBER"
print "*" * (len(card) - 4) + card[-4:]
Run Code Online (Sandbox Code Playgroud)
请注意,我已经避免使用该名称,str因为它已经是内置字符串类型的名称.使用影响内置名称的名称通常不是一个好主意.
对于那些想要保留发行人识别号(IIN)(以前称为“银行识别号”(BIN))的人,通常是前 6 位数字,应该可以:
print card[:6] + 'X' * 6 + card[-4:]
'455694XXXXXX6539'
Run Code Online (Sandbox Code Playgroud)