所以我有一个包含完整信用卡号码的csv文件..我们不需要完整的数字,所以我编写了一个快速脚本来解析csv,并用掩码表示替换cc数字。(除了最后四个之外都是*)。我是python的新手,我把它破解出来了,而且它还能用,但是为了学习,我想知道它是否可以更容易地完成。
假设"str“将是一个完整的信用卡号。但是对于我的例子,我只是使用字符串"CREDITCARDNUMBER“。
str = "CREDITCARDNUMBER";
strlength = len(str)
masked = strlength - 4
slimstr = str[masked:]
print "*" * masked + slimstr
输出结果就是我想要的
************MBER
但我相信有一个更优雅的解决方案。:)谢谢!
发布于 2012-03-16 09:51:32
更整洁一些:
>>> s = "CREDITCARDNUMBER"
>>> s[-4:].rjust(len(s), "*")
'************MBER'
发布于 2012-03-16 09:32:37
也许更优雅一点:
card = "CREDITCARDNUMBER"
print "*" * (len(card) - 4) + card[-4:]
请注意,我避免使用名称str
,因为它已经是内置字符串类型的名称。使用隐藏在内置名称后面的名称通常不是一个好主意。
发布于 2013-07-02 21:02:17
对于那些想要保留Issuer Identification Number (以前称为“银行识别码”)(通常是前6位数字)的人来说,这应该可以做到这一点:
print card[:6] + 'X' * 6 + card[-4:]
'455694XXXXXX6539'
https://stackoverflow.com/questions/9730653
复制相似问题