我有任何文字的字符串。它可以是这样的 - "abcdef 123456789521 zxcvb"
, - "45651256"
和 - "asdad 564654 sddsf 4"
。我想在文本PAN号中搜索,这可能是不同的长度,而不是用luhn
算法验证它。我知道,我可以通过regx找到它,但它需要这样的表达 - "Pattern.compile("[A-Z]{5}[0-9]{4}[A-Z]{1}");
。但是我不知道我的字符串将包含多少个字符和数字以及它们的顺序。可能有人知道怎么做吗?有什么建议吗?
答案 0 :(得分:2)
我认为PAN是指信用卡号(see PAN on wikipedia)。
根据那篇文章,数字必须在8到19位之间。因此,您在文本中搜索具有该间隔长度的数字,存储它们并使用Luhn algorithm进行检查。这是一个实现,它可以找到长度在8到19位之间的数字并执行Luhn检查:
pip install dbus-python
import java.util.ArrayList;
import java.util.regex.Pattern;
import java.util.regex.Matcher;
public class main {
public static void main(String[] args) {
String text = "helloWor4712389062l648977135536d 239012390oife234923 uiwed wq12893129038";
ArrayList<String> result = getPossiblePANs(text);
for(String pan : result) {
System.out.print("Possible PAN: " + pan);
if(luhnCheck(pan))
System.out.println(" is valid!");
else
System.out.println(" is INVALID!");
}
}
static ArrayList<String> getPossiblePANs(String text){ //Numbers w. 8-19 digits
ArrayList<String> res = new ArrayList<>();
Pattern p = Pattern.compile("\\d{8,19}+");
Matcher m = p.matcher(text);
while(m.find())
res.add(m.group());
return res;
}
static boolean luhnCheck(String cardNumber){
if(cardNumber.length() < 8 || cardNumber.length() > 19)
return false;
int sum = 0;
int begin = cardNumber.length() - 2;
for(int i = begin; i >= 0; i-=2){
int number = Integer.parseInt(cardNumber.substring(i, i+1)) * 2;
if(number > 9) sum += (number - 9);
else sum += number;
}
return (sum % 10) == 0;
}
}