java 读取 txt 文件后的字符串截取问题

【问题】

20010-8-13 991003 3166.63 3332.57  3166.63  3295.11 
2010-8-10 991003 3116.31 3182.66  3084.2   3140.2 
2010-8-9 991003 3085.44 3140.31  3084.33  3108.31 
2010-8-7 991003 3203.14 3206.49  3136.42  3161.44 
2010-8-6 991003 3138.6 3205.76  3128.1   3205.54 
2010-8-3 991003 3114.36 3127.35  3063    3116.38 
这个是我要读取的txt文件中的一部分数据(原数据有几百行),现在我用readLine按行读取,现在我要按行计算最后四列的平均值 
3166.63 3332.57  3166.63  3295.11 
就是把这个平均值计算出来 
我本意是用readLine读出后,用substring截取,再将其强制转换成浮点数计算即可。但是现在每一行的空格符数不同,因此在用substring时括号里参数不同,几百行肯定不能每个都手动输入,所以现在我想有什么办法可以解决,获得后四列的数据并运算 

【回答】                                    

这个问题用SPL写吧,非常简单,也可以嵌入JAVA中使用


A

1

=file("E:\\s.txt").read@n()

2

=A1.(~.words@d())

3

=A2.(~.to(5,8).avg())

A1: 按行读取文本,一行为一个成员

A2:循环将每一行的字符串拆分成数字组成的序列

A3:循环取A2每个成员序列中的第5个到第8个数字,也就是原始文本中后四列的数据,并对这四个数据求平均值

写好的脚本如何在应用程序中调用,可以参考Java 如何调用 SPL 脚本