标签:
例XML:
<data type="REGEX">
<code>prop1</code>
<name>书名</name>
<method>
<![CDATA[
(?i)(?<=BookName\: \")([\u4e00-\u9fa5]+)
]]>
</method>
</data>
1)正则中含有<是会有错误的,需要进行处理;
2)注意和Java文件中的写法稍微不一样啊(反斜杠/) 多写一个结果就可能出不来了(⊙o⊙)哦
例Java:
public class TestRegex {
public static void main(String[] args) throws Exception {
String str ="BookName: \"我欲封天\",CategoryName: \"仙侠\", SubCategoryName: \"古典仙侠\"";
String regex = "(?i)(?<=CategoryName\\: \")([\u4e00-\u9fa5]+)";
System.out.println(getRegexValue(regex, str, true).toString());
}
public static Object getRegexValue(String regex, String html, boolean isList) {
if (isList == false) {
Pattern p = Pattern.compile(regex);
Matcher matcher = p.matcher(html);
return matcher.find() == true ? matcher.group() : null;
} else {
List<String> result = new ArrayList<String>();
Pattern p = Pattern.compile(regex);
Matcher matcher = p.matcher(html);
while (matcher.find()) {
result.add(matcher.group());
}
return result;
}
}
}
标签:
原文地址:http://my.oschina.net/u/2329222/blog/502449