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 脚本