我正在处理包含我想要提取的子字符串的字符串。子字符串的格式始终为"USX",其中US是字符串"US",X是任意长度的整数。
例如,考虑以下字符串:
对于以下字符串,我希望提取粗体文本。
str1 =s命令填充129 moreRand US2 $#@# o
str2 = US231随机!@@!
str3 =苹果或@nges 12 US1294
我到处寻找这样做的方法,但没有成功。我有办法解决这个问题吗?
发布于 2018-06-15 05:13:11
您可以使用regex来实现它。使用正则表达式(US\\d+),您将获得与"US“匹配的组,后跟任意长度的整数(最小值为1)。
import java.util.regex.Matcher;
import java.util.regex.Pattern;
...
Matcher matcher = Pattern.compile("(US\\d+)").matcher(str1);
if (matcher.find()) {// if it matched the pattern
String result = matcher.group(0);// the group captured by the regex
}发布于 2018-06-15 05:06:18
如果你想要的所有字符串都像上面那样用空格分隔,你可以使用split()。
例如,
String[] strArray1 = str1.split(" ");
for (String item : strArray1) { // Cycle through all the pieces
if (item.startsWith("US"))
String target = item; // Your desired String
}Split()将一个字符串分解成一个数组,每个元素都是分隔符之间的任何内容,在本例中是空格。
发布于 2018-06-15 05:02:50
您可以使用正则表达式(简称regex)来解决这类问题。
关于正则表达式,我喜欢的一个来源是https://www.regular-expressions.info/
https://stackoverflow.com/questions/50865760
复制相似问题