我有一个方法,它从用户那里获取(X,Y)坐标字符串。 X 和 Y 坐标的范围都是从 0 到 8,坐标可以是五种可能的格式之一:
- (4,3):括号内的 X 和 Y 坐标,并以逗号分隔且无空格
- 4 3:X 和 Y 坐标仅用空格分隔,无括号
- 4,3:X 和 Y 坐标仅用逗号分隔,无括号
- d 3:X 用字母表示。 0=A、1=B、...、8=H。 X 和 Y 用空格分隔
- d3:与上面相同,只是没有空格。
我遇到的问题是开发一种可以成功解析所有四种格式的方法。更具体地说,我想成功地将 X 和 Y 坐标转换为两个单独的整数并将它们存储在某个地方,无论使用哪种格式。
我对java有点陌生,并且没有太多解析字符串的经验。任何指示将不胜感激。
最佳答案
首先让我们考虑主格式。我们想要将所有这些转换为一种格式,以便最终将它们转换为两个整数。让我们将此格式设置为两个由空格分隔的数字。在我看来,这是最容易解析的。
然后,让我们考虑一下这些共享的模式。例如,保证第一个输入只有括号,因此我们可以轻松识别。第三个保证包含逗号,但不包含括号。因此,我们可以用一个规则将它们分组,如果有逗号,则删除括号(如果有)并将逗号替换为空格。
已经落后 3 场,还剩 2 场。
现在,最后两个有什么共同点?他们分享一封信。我们可以使用正则表达式轻松捕获这封信,但我们稍后再担心这一点。那么,让我们制定一个逻辑规则。
如果,该短语没有逗号, 我们检查它是否有一封信。如果是,我们检查它是否有空格。 如果是这样,我们按空格分割,并用其整数等效值替换该字符,并正确偏移以表示其在字母表中的位置。 否则,我们使用正则表达式按字母进行分割,并执行上述操作。
现在我们脑海中已经清楚地知道我们想要实现什么,让我们尝试自己做吧。
这就是我在代码中的做法。
public int[] parseXYCoord(String s) {
String master=s;
if(s.contains(",")){
master=master.replace("(","").replace(")","");
master=master.replace(","," ");
}else if(master.matches("^[a-z]((\\s[0-8])|[0-8])$")){
int charValue=master.charAt(0)-'a'+1;
master=charValue+" "+master.charAt(master.contains(" ")?2:1);
}
return parseMaster(master);
}
private int[] parseMaster(String master) {
if(!master.matches("^[0-8] [0-8]$"))
throw new IllegalArgumentException("Inputted Number is incorrect!");
String[] splitMaster=master.split(" ");
return new int[]{Integer.parseInt(splitMaster[0]),Integer.parseInt(splitMaster[1])};
}
我不太擅长正则表达式。虽然它很丑陋,但它确实完成了工作。查看网站DebugRegex如果您想学习如何使用正则表达式。
使用测试
System.out.println(Arrays.toString(parseXYCoord("4,3")));
System.out.println(Arrays.toString(parseXYCoord("4 3")));
System.out.println(Arrays.toString(parseXYCoord("(4,3)")));
System.out.println(Arrays.toString(parseXYCoord("d3")));
System.out.println(Arrays.toString(parseXYCoord("d 3")));
打印
[4, 3]
[4, 3]
[4, 3]
[4, 3]
[4, 3]
关于java - (Java) 如何解析具有多种可能格式的坐标字符串,并将它们转换为整数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52249376/