我有一个很长的字符串,我想基于规则进行拆分。 我的字符串是:
[1] (dokuma) deve, öküz, at tüyü, keçi kılı veya koyun yününün sıkıştırılarak sertleştirilmesiyle imal edilen ve giyecek yapımında kullanılan kalın ve kaba kumaş [2] (giyim) kumaştan yapılan yakasız bol ve uzun üstlük [3] (halk ağzı) abla, anne [4] (halk ağzı) dar pantolon üzerine giyilen ceket
我希望显示如下:
[1] (dokuma) deve, öküz, at tüyü, keçi kılı veya koyun yününün sıkıştırılarak sertleştirilmesiyle imal edilen ve giyecek yapımında kullanılan kalın ve kaba kumaş
[2] (giyim) kumaştan yapılan yakasız bol ve uzun üstlük
[3] (halk ağzı) abla, anne
[4] (halk ağzı) dar pantolon üzerine giyilen ceket
我的代码是:
String[] strMeaning = meanings.text().split("[");
for(String key : strMeaning)
{
System.out.println(key);
}
我看到的错误是:
Exception in thread "main" java.util.regex.PatternSyntaxException: Unclosed character class near index 0
[
^
at java.util.regex.Pattern.error(Unknown Source)
at java.util.regex.Pattern.clazz(Unknown Source)
at java.util.regex.Pattern.sequence(Unknown Source)
at java.util.regex.Pattern.expr(Unknown Source)
at java.util.regex.Pattern.compile(Unknown Source)
at java.util.regex.Pattern.<init>(Unknown Source)
at java.util.regex.Pattern.compile(Unknown Source)
at java.lang.String.split(Unknown Source)
at java.lang.String.split(Unknown Source)
at wikipedia.CreateXML.wordMeaning(CreateXML.java:39)
at wikipedia.CreateXML.prepareData(CreateXML.java:33)
at wikipedia.Main.main(Main.java:32)
我无法弄明白。我怎么能分开我想要的方式?提前致谢
答案 0 :(得分:5)
打开方括号[
是一个特殊字符,用于表示character class的开头,您需要将其转义:
meanings.text().split("\\[");
答案 1 :(得分:3)
[是Java正则表达式中的一个特殊字符。
尝试这样的事情:
String[] temp = text.split("\\[");
答案 2 :(得分:1)
你需要转义方括号,因为这是正则表达式中的一个特殊字符,用于执行匹配。但是,您还需要转义转义,因为java中的反斜杠具有特殊含义。你最终得到了
String[] strMeaning = meanings.text().split("\\[");
for(String key : strMeaning)
{
System.out.println("[" + key);
}
我添加了println
中的额外位,因为“[”中的匹配将删除括号。
答案 3 :(得分:1)
我使用以下内容:String[] strMeaning = meanings.text().split("\s(?=\[)");
。您不希望拆分[
,而是拆分下一个[
之前的空间。