从CSV文件中读取数据。将数据转换为数组

时间:2013-03-25 00:53:47

标签: java csv multidimensional-array

我正在尝试完成一个项目,但我没有运气。这是一个在线课程,所以我唯一的沟通是通过电子邮件。在过去的五天里,他还没有回复我的四封电子邮件。

因此,对于此作业,我们必须从包含特定公司的纳斯达克股票价格信息下载csv文件。我选择了GOOG(谷歌)。以下是代码部分的要求。

创建第二个文件ReadFiles.java。这是将从csv文件中读取数据的文件。注意:您需要使用较小版本的数据文件(20行)进行测试。 您的ReadFiles.java类需要以下方法:

方法:检查文件是否存在

方法:查找csv文件中的行数

方法:将csv文件转换为多维数组

方法:PrintArray

方法:使用get方法返回数组

创建一个DataAnalyzer.java文件。该文件将用于调用ReadFiles.java中的方法。请务必通过DataAnalyzer.java演示所有方法。

这是我到目前为止所做的。

package Analysis;

import java.io.BufferedReader;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.IOException;
import java.io.Reader;
import java.util.StringTokenizer;
import java.util.Scanner;

public class ReadFiles 
{
    public static int numberOfRows;
    public static int rowNumber = 0;
    public static int columnNumber = 0;

    public static void main(String[] args) 
    {
        Scanner kb = new Scanner (System.in);
        String fileName;
        System.out.print("Enter the file name >> ");
        fileName = kb.nextLine();
        File f = new File("D:\\Java\\Assignment 3\\" + fileName);
        if(f.exists())
        {
            System.out.print("File exists.");
        }
        fileName="D:\\Java\\Assignment 3\\" + fileName;
        try 
        {
            BufferedReader br = new BufferedReader(new FileReader(fileName));
            StringTokenizer st = null;

            while((fileName = br.readLine()) != null)
            {
                rowNumber++;
                numberOfRows++;

                st = new StringTokenizer(fileName, ",");

                while(st.hasMoreTokens())
                {
                        columnNumber++;
                        System.out.println("Row " + rowNumber + 
                                    ", Column " + columnNumber 
                                + ", Entry : "+ st.nextToken());
                }
                columnNumber = 0;
            }
        }       
        catch (FileNotFoundException e) 
        {
            e.printStackTrace();
        } 
        catch (IOException e) 
        {
            e.printStackTrace();
        }
    }
    public static void rows()
    {
        System.out.println("Total Rows: " + numberOfRows);
    }
}

我们为该课程提供的那本书没有任何帮助。所有“示例”和“你做它”部分都会出错。同样在整个章节中,这个赋值是基于,而不是一个数组的提及。

当我运行此代码时,我没有收到任何错误。我看到以下内容:

File exists.
Row 1, Column 1, Entry : 30/12/2011
Row 1, Column 2, Entry : 642.02
Row 1, Column 3, Entry : 646.76
Row 1, Column 4, Entry : 642.02
Row 1, Column 5, Entry : 645.9
Row 1, Column 6, Entry : 1782300
Row 1, Column 7, Entry : 645.9
Row 2, Column 1, Entry : 29/12/2011
Row 2, Column 2, Entry : 641.49

我从第1 - 19行显示(整个文件)。

我不明白的是如何在此类中创建单独的方法以转换为数组,打印数组并返回数组。

非常感谢任何帮助。

由于

1 个答案:

答案 0 :(得分:0)

您需要定义2个类,DataAnalyzer和ReadFiles。您通常每个类有一个文件,但这不是必需的。已经提供了ReadFiles的结构,因此您将有一个名为ReadFiles.java的文件,如下所示:

public class ReadFiles{

    //instance var(s)
    ...

    //constructor(s)
    ...

    //methods(s)

    /**
      * Checks whether the file exists
     */
    public boolean exists(){
        ....
    }

    /*
     * Number of rows in the file
     */
    public int getRowCount(){
        ....
    }

    // add the rest your self!!
}

}

您还需要一个名为DataAnalyzer.java的文件:

public class DataAnalyzer{

    public static void main(String args){
        //create ReadFiles and call it's methods and check they return what is expected
    }

}

假设ReadFile管理单个输入文件;它可能需要一个类变量来保存该信息。 DataAnalyzer需要告诉ReadFiles要分析哪个文件(构造函数似乎是一个不错的选择)。

我的建议是创建你的骨架结构(你已经被告知它是什么)并开始逐个构建每个方法的功能。