有一个字符串:“USER_ID=427;USER_NAME=王 耀,USER_ID=428;USER_NAME=范仁超,USER_ID=429;USER_NAME=俞姗姗”,
现在我想取出其中所有分号前面的数字,也就是[427,428,429],注意USER_NAME也有可能为数字,但是我不需要取出人名。
请教大虾帮助!在线等!急!
现在我想取出其中所有分号前面的数字,也就是[427,428,429],注意USER_NAME也有可能为数字,但是我不需要取出人名。
请教大虾帮助!在线等!急!
解决方案 »
- 有关jfreechar????
- 菜鸟问题 system.out.write怎么不行?多谢!
- 文件遍历问题
- 请问jbuilder7中有没有像VC中的group box的控件
- mysql数据库的转码问题,急急急!
- 高分求购jbuilder6.0的注册码!急 急!
- 数据库问题(大家快来帮把手,实在不行,我可以再放100分)
- catch异常的时候用System.out.print()和用System.err.print()来输出有什么区别啊?
- 谁能帮我解决这个问题,我的分全不奉送
- java用swing插件把数据库中的数据表示出来
- eventobject很简单的一个问题都来看看吧
- import问题???
public static void main(String[] args) {
// 把你的例子中的一个USER_NAME改成了数字用以测试.
String str = "USER_ID=427;USER_NAME=王 耀,USER_ID=428;7452=范仁超,USER_ID=429;USER_NAME=俞姗姗";
// 下面两个正则规则任选一个都可以
String regex = "\\d+[\\s]*;";
// regex = "=[\\s]*\\d+[\\s]*;";
Pattern pattern = Pattern.compile(regex);
Matcher mather = pattern.matcher(str); while (mather.find()) {
String number = mather.group().replace(";", "").replace("=", "").trim();
System.out.println(number);
}
}
}
测试结果:
427
428
429
不好意思, 上面的测试用例中用户名改错地方了, 使用下面这个, 不过没关系, 都不影响程序的正确提取数据:
"USER_ID=427;USER_NAME=王 耀,USER_ID=428;USER_NAME=7452,USER_ID=429;USER_NAME=俞姗姗";