我想编写一个程序,使其按顺序返回每个子字符串(来自字符串)的ArrayList。
static boolean tropChangements(String branche, int ocurrTaches) {
ArrayList dispositif = new ArrayList();
String pub = "[public]";
String priv = "[private]";
String brancheDecoup;
int ptVirg = branche.indexOf(" ; ");
for(int i = 0; i<ocurrTaches; i++) {
brancheDecoup = [...] //use ptVirg
if (brancheDecoup.contains(pub)) {
dispositif.add("public");
} else if (branche.contains(priv)) {
dispositif.add("private");
}
}
//[...] It's OK here
}
因此,我希望在“ BrancheDecoup”中仅出现我的子字符串的第一次出现,然后出现下一个,下一个等等(字符串的末尾带有“。”)
我的字符串,例如: EcrireNomEtudiant [public]; EntrerMDP [private]; AvecQui [private]; ChoisirJour [perso]; VerifDisponibilites [system]; AfficherRecupilatif [private]; EnvoyerLaDemande [system]。
我想要这个结果->
在ArrayList中:“公共”,“私有”,“私有”,“ perso”,“私有”
非常感谢您。
最好的问候, 文森特。
答案 0 :(得分:3)
您可以先拆分字符串,然后使用正则表达式匹配模式
Pattern p = Pattern.compile("\\[(.*?)]");
String str = "EcrireNomEtudiant[public] ; EntrerMDP[private] ; AvecQui[private] ; ChoisirJour[perso] ; VerifDisponibilites[system] ; AfficherRecupilatif[private] ; EnvoyerLaDemande[system]";
Function<String, String> finder = s -> {
Matcher m = p.matcher(s);
return m.find() ? m.group(1) : null;
};
List<String> list = Arrays.stream(str.split(";"))
.map(finder)
.collect(Collectors.toList());
System.out.println(list);
答案 1 :(得分:2)
不确定我是否完全了解您要做什么,但这将为您提供期望的输出:
List<String> dispositif = new ArrayList<>();
Pattern re = Pattern.compile("\\[(public|private|perso)\\]");
Matcher matcher = re.matcher(branche);
while (matcher.find()) {
dispositif.add(matcher.group(1));
}
答案 2 :(得分:1)
尝试一下:
import java.util.HashSet;
import java.util.Set;
public class Main {
public static void main(String[] args) {
String sample = "EcrireNomEtudiant[public] ; EntrerMDP[private] ; AvecQui[private] ; ChoisirJour[perso] ; VerifDisponibilites[system] ; AfficherRecupilatif[private] ; EnvoyerLaDemande[system].";
tropChangements(sample);
}
static void tropChangements(String branche) {
Set<String> dispositif = new HashSet<String>(); // use Set so that there will be no duplicates
String[] branches = branche.split(";"); // use split method to split string by ";"
for (String s : branches) { // iterate string
int indexOfOpen = s.indexOf("["); // get the index of "["
int indexOfClose = s.lastIndexOf("]"); // get the index of "]"
if (indexOfOpen > 0 && indexOfClose > 0) { // check if both "[" and "]" is found
String tmp = s.substring(indexOfOpen + 1, indexOfClose); // get the needed string
dispositif.add(tmp); //add it to the set
}
}
System.out.println(dispositif); // print the set
}
}
结果:[perso, private, system, public]
答案 3 :(得分:1)
考虑Apache Commons Lang lib 的用法,这使得上面的( @sidgate )代码更加清晰。
因此,完整的清单将是:
import java.util.Arrays;
import java.util.List;
import java.util.stream.Collectors;
import org.apache.commons.lang.StringUtils;
public class Example {
static String sample =
"EcrireNomEtudiant[public] ; EntrerMDP[private] ; AvecQui[private] ; ChoisirJour[perso] ; VerifDisponibilites[system] ; AfficherRecupilatif[private] ; EnvoyerLaDemande[system]";
public static void main(String[] args) {
tropChangements(sample);
}
static void tropChangements(String branche) {
List<String> list = Arrays
.stream(branche.split(";"))
.map(String::trim)
.map(s -> StringUtils.substringBetween(s, "[", "]"))
.collect(Collectors.toList());
System.out.println(list);
}
}