从网上找的代码如下:
//取字符串中的数字
public String checkNum(String str) {
// String str = "abcd123和345.56jia567.23.23jian345and23or345.56";
//先判断有没有整数,如果没有整数那就肯定就没有小数
Pattern p = Pattern.compile("(\\d+)");
Matcher m = p.matcher(str);
String result = "";
if (m.find()) {
Map<Integer, String> map = new TreeMap();
Pattern p2 = Pattern.compile("(\\d+\\.\\d+)");
m = p2.matcher(str);
//遍历小数部分
while (m.find()) {
result = m.group(1) == null ? "" : m.group(1);
int i = str.indexOf(result);
String s = str.substring(i, i + result.length());
map.put(i, s);
//排除小数的整数部分和另一个整数相同的情况下,寻找整数位置出现错误的可能,还有就是寻找重复的小数
// 例子中是排除第二个345.56时第一个345.56产生干扰和寻找整数345的位置时&#x