我正在读取多个字符串,并将它们添加到Vector中,如下所示。
public void readCode(){
BufferedReader abc;
try {
abc = new BufferedReader(new FileReader("code.txt"));
String line;
while((line = abc.readLine()) != null) {
lines.add(line);
}
abc.close();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
for(int i = 0;i<lines.size();i++){
String x=lines.get(i);
String[] split = x.split("#");
vkCode.add(split[0]);
vkName.add(split[1]);
}
}然后我用这个代码来找到特定项目名的项目代码。
String cmpre="";
banding = sc.nextLine();
int target = -1;
for(int p = 0;p<vkName.size();p++){
if(vkName.get(p).toString().toLowerCase().contains(cmpre)){
target=p;
break;
}
}
if(target==-1){
System.out.println("Item does not exist!");
}
else{
System.out.println("Item Code is : "+vkCode.get(target));
}到目前为止,代码运行良好,但存在一个问题。
假设项目清单如下所示。
编辑请求:数据示例
1213112#PT ABC Syariah Tbk
1212112#PT ABC Tbk
1241312#PT ABC Central Tbk案例1:如果我们试图找到ABC,预期的结果是PT ABC Tbk ID,它是1212112,但是由于我的代码,它将导致PT ABC Syariah Tbk ID
案例2:如果我们试图找到Syariah ABC,它将根本不会返回任何代码。由于文本文件具有ABC Syariah,这也是一个问题。
发布于 2018-04-04 01:51:36
首先使用.contains()生成一组模糊匹配。然后,从该集合中,使用.equals()生成第二个精确匹配集合。如果有,则返回第一个精确匹配,如果有,则返回第一个模糊匹配,否则返回null。
https://stackoverflow.com/questions/49641469
复制相似问题