例如,我有前边界'x'和后边界'y'
E.G。 给定一个字符串'abcxfoobaryblablah',它应该返回'foobar'。
假设两个边界在字符串中只出现一次,如示例所示。
谢谢!不必使用正则表达式,但我想这是最好的方法。
答案 0 :(得分:6)
String s = "abcxfoobaryblablah";
s = s.substring(s.indexOf('x') + 1, s.indexOf('y'));
System.out.println(s);
停止
foobar
答案 1 :(得分:0)
答案 2 :(得分:0)
可能是一个很长的代码,但只是一个简单的逻辑。
String str="abcxfoobaryblablah";
char array[]=str.toCharArray();
boolean flag=false;
String answer="";
for(int i=0;i<array.length;i++)
{
if(array[i]=='x'){
flag=true;
continue;
}
if(array[i]=='y') break;
if(flag)answer+=array[i];
}
System.out.println(answer);
答案 3 :(得分:0)
String input = "abcxfoobaryblablah";
int startIndex = input.indexOf("x");
int endIndex = input.indexOf("y");
String output = input.substring(startIndex+1, endIndex);
System.out.println(output);
答案 4 :(得分:0)
你当然可以做子串,但是可以使用正则表达式。
String str = "abcxfoobaryblablah";
str = str.replaceAll("^.*x|y.*$", "");
^.*x
匹配从String
开始到x
的字符。 y.*$
匹配y
到String
末尾的字符。
请注意,如果x
位于y
之后,那么x
之后的字符只会保留在String
的末尾。如果x
不存在,则会将字符从String
开始保持为y
。如果您只希望 <{strong> x
和y
以正确的顺序存在,那么这就是您想要的:
String str = "abcxfoobaryblablah";
str = str.replaceAll("^.*x(.*)y.*$", "$1");
这使用groups。
答案 5 :(得分:0)
最简单的方法是:
String middle = str.replaceAll(".*x(.*)y.*", "$1");