如何解析一个字符串并一次获得一个子字符串一次?

时间:2019-07-04 08:47:41

标签: java string substring

我想编写一个程序,使其按顺序返回每个子字符串(来自字符串)的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”,“私有”

非常感谢您。

最好的问候, 文森特。

4 个答案:

答案 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);
  }
}