数据如下:
零件代号 col1 col2 col3
A 11 12 10
B 22 20 13
现在遇到这样一个问题,根据零件代号判断当前行的零件代号是否与上一行的零件代号相同,如果相同则计算3*2列数据的平均值,如上述列表数据,如果第二行的零件代号B是A的话,则平均值=(11+12+10+22+20+13)/6,否则分别计算出各行数据的平均值,很郁闷不知道用java循环如何实现了,知道的同学帮忙解答一下,非常感谢!
补:这里的记录行数有很多,只需要与上一行相比即可。
List list = 查询数组;
List finalList = new ArrayList ();
for(int i=0;i<list.size();i++){
if(i==0){
Object[] o = list.get(i);
float avg = (Integer.valueof(o[1].toSring())+Integer.valueof(o[2].toSring())+Integer.valueof(o[3].toSring()))/3;
Object[] ob = new Object[5];
ob[0] = o[0];
ob[1] = o[1];
ob[2] = o[2];
ob[3] = o[3];
ob[4] = avg;
}else{
Object[] o = list.get(i);
Object[] o1 = list.get(i-1);
float avg = 0;
if(o[0].toSring().equals(o1[0].toSring())){
avg= (Integer.valueof(o[1].toSring())+Integer.valueof(o[2].toSring())+Integer.valueof(o[3].toSring())+Integer.valueof(o1[1].toSring())+Integer.valueof(o1[2].toSring())+Integer.valueof(o1[3].toSring()))/6;
}else{
avg = (Integer.valueof(o[1].toSring())+Integer.valueof(o[2].toSring())+Integer.valueof(o[3].toSring()))/3;
}
Object[] ob = new Object[5];
ob[0] = o[0];
ob[1] = o[1];
ob[2] = o[2];
ob[3] = o[3];
ob[4] = avg;
finalList.add(ob);
}
}
数据是在数据库中么?如果是用sql来处理更简单方便
上面的两行数据是界面显示?还是在后台?
你每行都存储一个他们的和值,然后比较相同后把上一个的和值加上当前行的和值再/6就好了。
如果连着三行 代号 都相同怎么办?
还有就是这写数据都是从数据库里面直接取出的吗?
你的数据是文件的还是数据库字段,文件的就截取,是数据库的话就取到对象里面!
看你这个应该是文件,你先取总的行数吧! 用BufferReaded类吧! 然后取每行的开头放数组,有了总行数,有了开头零件代号,结果就好算了!
将查询的出来的结果集循环,如果是第一行则平均值为该行平均数,否则(如果本行的号码和上行的编号相同,平均数为6个数的平均值,否认取该行三个数的平均数)