【问题标题】:How do I add the values I have gotten through parse to get the "value" of the "column"?如何添加通过解析获得的值以获取“列”的“值”?
【发布时间】:2015-11-20 21:54:30
【问题描述】:

我的代码通过输入文件并将其分成“列”。

System.out.println(numberdouble);

它打印出该列中每一行的值。我对此进行了测试以检查我的程序是否会正确地遍历列。我想知道如何输出每列的总和。

例子:

[a, 1, 2, 3]
[3, v, 3, x]
[5, 1, d, c]

如果我对第 0 列的值求和,我希望它把 3 和 5 加在一起。如果列中的值不是数字,则应将该值转换为 0。

我的代码:

public static Double column_sum(String filename, int column)
{
    if(column < 0)
    {
        return null;
    }
    File temp = new File(filename);
    Scanner input_file;
    try
    {
        input_file = new Scanner(temp);
    }
    catch (Exception e)
    {
        return null;
    }
    ArrayList<ArrayList<String>> result = new ArrayList<ArrayList<String>>();
    while(input_file.hasNextLine())
    {
        String line = input_file.nextLine();
        List<String> myList = new ArrayList<String>(Arrays.asList(line.split(",")));
            Double numberdouble =0.0;
            String numberstring = myList.get(column);
            if(isDouble(numberstring))
            {
              numberdouble = Double.parseDouble(numberstring);
            }
            else
            {
              numberdouble=0.0;
            }
            System.out.println(numberdouble);
    }
    return 1.23; //placeholder
}

【问题讨论】:

  • 您的示例中的预期输出是什么,而 column 分别为 0、1、2 和 3?
  • 列:答案 0:8 1:2 2:5 3:3
  • 知道了,请看我的回答:-)

标签: java loops arraylist add


【解决方案1】:

您要做的是创建一个二维矩阵。并将值存储在其中。完成此操作后,将很容易解析和添加列。 按照你的例子:

Double [][] myMatrix = new Double[3][4];
int counter = 0, rowIndex=0,columnIndex=0;
while(input_file.hasNextLine())
{   counter++;
    if(counter%4 == 0)
    {
        rowIndex++;
        columnIndex=0;
    }
    String line = input_file.nextLine();
    List<String> myList = new ArrayList<String>(Arrays.asList(line.split(",")));
        Double numberdouble =0.0;
        String numberstring = myList.get(column);
        if(isDouble(numberstring))
        {
          numberdouble = Double.parseDouble(numberstring);
        }
        else
        {
          numberdouble=0.0;
        }
        myMatrix[rowIndex][columnIndex++] = number double;
        System.out.println(numberdouble);
}

注意:索引将严格按照您的示例进行跟踪。您可以使其更具可配置性。

【讨论】:

  • 有没有办法使用我所拥有的?我只想知道如何添加值,因为输入文件有更多的列和行,我不想将行和列的数量硬编码到矩阵中
  • 是的,您可以按照您想要的方式进行操作,而不是使用可以动态增长的 List 的二维数组。仅保留每一列的总字符串,因此列表中的第 0 个元素是总第 1 列,依此类推。
【解决方案2】:

请看下面的代码(我已经测试过了)。由于我不知道您的 isDouble 函数的实现,因此我构建了一个简单(但不优雅)的函数。我还注释了两行未使用的行,并添加了input_file.close(); 以关闭资源。 “test.txt”的内容和你输入的例子一模一样:

a,1,2,3
3,v,3,x
5,1,d,c

代码:

import java.io.File;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.Scanner;

public class ColumnSum {
    public static void main(String[] args) {
        System.out.println(column_sum("test.txt", 0));
        System.out.println(column_sum("test.txt", 1));
        System.out.println(column_sum("test.txt", 2));
        System.out.println(column_sum("test.txt", 3));
    }

    public static boolean isDouble(String s) {
        try {
            Double.parseDouble(s);
            return true;
        } catch (Exception e) {
            return false;
        }
    }

    public static Double column_sum(String filename, int column) {
        Double sum = 0.0;
        if (column < 0) {
            return null;
        }
        File temp = new File(filename);
        Scanner input_file;
        try {
            input_file = new Scanner(temp);
        } catch (Exception e) {
            return null;
        }
        // ArrayList<ArrayList<String>> result = new ArrayList<ArrayList<String>>();
        while (input_file.hasNextLine()) {
            String line = input_file.nextLine();
            List<String> myList = new ArrayList<String>(Arrays.asList(line.split(",")));
            Double numberdouble = 0.0;
            String numberstring = myList.get(column);
            if (isDouble(numberstring)) {
                numberdouble = Double.parseDouble(numberstring);
                sum += numberdouble;
            } else {
                numberdouble = 0.0;
            }
            // System.out.println(sum);
        }
        input_file.close();
        return sum;
    }
}

输出是(对于每一列):

8.0
2.0
5.0
3.0

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2022-01-18
    • 2014-06-20
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2019-08-19
    相关资源
    最近更新 更多