代码如下所示:
package test3;
/**
* 查找文本中的数字并求和(工程师)
* @author saicy(博客 http://blog.csdn.net/sai739295732)
*/
import java.util.LinkedHashMap;
import java.util.Map;
import java.util.Scanner;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class test6 {
private static Scanner scan;
public static void main(String[] args) {
test6 t = new test6();
//输入hello world 2300 at 2010, 9# Beijing
scan = new Scanner(System.in);
String str=scan.nextLine();
t.getString( str, "[0-9]+");
}
private Map<String,Integer> getString(String str, String regx) {
Map<String,Integer> map = new LinkedHashMap<>();
//1.将正在表达式封装成对象Patten 类来实现
Pattern pattern = Pattern.compile(regx);
//2.将字符串和正则表达式相关联
Matcher matcher = pattern.matcher(str);
//3.String 对象中的matches 方法就是通过这个Matcher和pattern来实现的。
//System.out.println(matcher.matches());
//查找符合规则的子串
int count =0;
while(matcher.find()){
//匹配数据累加
count +=Integer.parseInt(matcher.group());
}
//找到的所有数字之和,上面例子,即 2300 + 2010 + 9的计算结果,即:4319
System.out.println(count);
return map;
}
}
输出结果:
本程序是本人原创,是一定能够输出结果的。谢谢大家的支持。