ArrayList readCSV(String filepath)

原创 2004年04月07日 16:31:00

小第不才,从google里搜索出了一个读CSV文件的好方法,我通过垃圾的日化,现程现给大家,希望能够帮助那些有困难的朋友.

/**
   * 方法はCSVファイルを読むことができ、ArrayListを返します。
   * @param fullPathFilename CSVファイルのディレクトリー
   * @param numToRead  方法はどれだけのラインを(読み取り)もたらすだろうか
   * @return arrlist
   * @throws IOException
   */
  public  ArrayList readCSVTwoParam(String fullPathFilename,int numToRead) throws IOException{
    BufferedReader reader = new BufferedReader(new FileReader(fullPathFilename));
    String line;
    StringTokenizer st;
    int size = 0;
    int index = 0;
    int pos = 1; //第1個の位置を越える
    String[][] data;
    String[][] temp;
    final int DEFAULT_SIZE = 250;
    final String DELIMITER = ",";
    int maxRecords;
    ArrayList arrlist = null;
    ArrayList arrlist1 = null;

    //読み取りラインの数を計算します。
    line = reader.readLine();
    st = new StringTokenizer(line, DELIMITER);
    while (st.hasMoreElements()) {
      st.nextElement();
      size++;
    }

    //配列を分類する、場合、セットされないパラメーター、全ファイルを読む、
    //要求されるようにそうでなければ止まります。
    if (numToRead == 0) {
      numToRead = DEFAULT_SIZE;
      maxRecords = Integer.MAX_VALUE;
    }
    else {
      maxRecords = numToRead;
    }

    data = new String[numToRead][size];

    //配列を増すためにそれを再び行います。
    st = new StringTokenizer(line, DELIMITER);
    while (st.hasMoreElements()) {
      data[0][index] = st.nextElement().toString();
      index++;
    }
    index = 0;

    //さて房を行ってください..
    while ( (line = reader.readLine()) != null && pos < maxRecords) {
      st = new StringTokenizer(line, DELIMITER);
      while (st.hasMoreElements()) {
 if (index == data[0].length)
   break;
 data[pos][index] = st.nextElement().toString();
 index++;
      }
      index = 0;
      pos++;

      if (pos == data.length - 1) { //もし必要ならばサイズ配列。
 temp = new String[data.length + numToRead][size];
 for (int n = 0; n < data.length; n++) {
   System.arraycopy(data[n], 0, temp[n], 0, temp[n].length);
 }
 data = temp;
      }
    }
    //配列を正確に分類してください..それは大きすぎますかもしれません
    temp = new String[pos][size]; //読まれたサイズ
    for (int n = 0; n < temp.length; n++) {
      System.arraycopy(data[n], 0, temp[n], 0, temp[n].length);
    }
    reader.close();

    //ArrayListへストリングを交換します。
      for (int i = 0; i < temp.length; i++) {
      arrlist = new ArrayList();
      for (int j = 0; j < temp[i].length; j++) {
      arrlist1 = new ArrayList();
      arrlist1.add(temp[i][j]);
      }
      arrlist1=null;
      arrlist.add(arrlist1);
   }
    return arrlist;
  }


  /**
   * 方法はCSVファイルを読むことができ、ArrayListを返します。
   * @param fullPathFilename CSVファイルのディレクトリー
   * @return arrlist
   * @throws IOException
   */
public  ArrayList readCSV(String fullPathFilename) throws IOException{
    String line;
    StringTokenizer st;
    int size = 0;
    int index = 0;
    int pos = 1; //第1個の位置を越える
    String[][] data;
    String[][] temp;
    final int DEFAULT_SIZE = 250;
    final String DELIMITER = ",";
    int maxRecords;
    int numToRead=0;
    int chr,k=0;
    StringBuffer buf=new StringBuffer();
    ArrayList arrlist = null;
    ArrayList arrlist1 = null;

    //読み取りラインの数を計算します。
    BufferedReader reader1 = new BufferedReader(new FileReader(fullPathFilename));
    while ( (chr = reader1.read()) != -1) {
      buf.append( (char) chr);
    }
    if((buf.substring(k,k+1).equals("/n")==true)||
      (k+1==buf.length()))
      numToRead++;
    //数組の容量の大きさを得る
     BufferedReader reader = new BufferedReader(new FileReader(fullPathFilename));
    line = reader.readLine();
    st = new StringTokenizer(line, DELIMITER);
    while (st.hasMoreElements()) {
      st.nextElement();
      size++;
    }

    //配列を分類する、場合、セットされないパラメーター、全ファイルを読む、
    //要求されるようにそうでなければ止まります。

    if (numToRead == 0) {
      numToRead = DEFAULT_SIZE;
      maxRecords = Integer.MAX_VALUE;
    }
    else {
      maxRecords = numToRead;
    }

    data = new String[numToRead][size];

    //配列を増すためにそれを再び行います。
    st = new StringTokenizer(line, DELIMITER);
    while (st.hasMoreElements()) {
      data[0][index] = st.nextElement().toString();
      index++;
    }
    index = 0;

    //さて房を行ってください..
    while ( (line = reader.readLine()) != null && pos < maxRecords) {
      st = new StringTokenizer(line, DELIMITER);
      while (st.hasMoreElements()) {
 if (index == data[0].length)
   break;
 data[pos][index] = st.nextElement().toString();
 index++;
      }
      index = 0;
      pos++;

      if (pos == data.length - 1) { //もし必要ならばサイズ配列。
 temp = new String[data.length + numToRead][size];
 for (int n = 0; n < data.length; n++) {
   System.arraycopy(data[n], 0, temp[n], 0, temp[n].length);
 }
 data = temp;
      }
    }
    //配列を正確に分類してください..それは大きすぎますかもしれません
    temp = new String[pos][size]; //読まれたサイズ
    for (int n = 0; n < temp.length; n++) {
      System.arraycopy(data[n], 0, temp[n], 0, temp[n].length);
    }
    reader.close();

    //ArrayListへストリングを交換します。
      for (int i = 0; i < temp.length; i++) {
      arrlist = new ArrayList();
      for (int j = 0; j < temp[i].length; j++) {
      arrlist1 = new ArrayList();
      arrlist1.add(temp[i][j]);
      System.out.println("temp[i][j] = " + j +" ="+temp[i][j]);
      }
      arrlist1=null;
      arrlist.add(arrlist1);
      System.out.println("arrlist1 = " + i +" =");
   }
    return arrlist;
  }

java ArrayList 转 string 便捷方法

使用:org.apache.commons.lang 的 lei
  • Java_HYL
  • Java_HYL
  • 2014年06月11日 18:37
  • 2451

常见List<String> 与ArrayList <String >之间

常见的语句: List  list = new ArrayList(); 而不是写成: ArrayList list = new ArrayList(); ???????? List是接口,...
  • huineyHuang
  • huineyHuang
  • 2014年02月21日 14:32
  • 2113

Android的ArrayList<String> 的用法

一 再现整理ArrayList 的用法 1 定义、初始化 private ArrayList menus = new ArrayList(); 2 赋值 for(cursor.moveToFir...
  • u011736532
  • u011736532
  • 2015年03月04日 14:28
  • 1559

ArrayList<String> 转化为String数组问题

ArrayList heightArrayList = new ArrayList(); for (int i = 20; i
  • Caesardadi
  • Caesardadi
  • 2013年10月14日 14:59
  • 18228

【Java】ArrayList<String>转化为String数组问题

Java的容器类Collections中toArray()方法,可以把诸如ArrayList的动态数组、不定长转化静态数组、定长数组String[] 但是,如下的转化方式是错误的。 String[...
  • yongh701
  • yongh701
  • 2015年04月21日 11:23
  • 8643

Java ArrayList使用总结(一)

   最近一直在使用Java,感觉它的越界检查非常有效。这一点对于初学者来说是非常重要的(提高程序的严谨性),对于有经验的程序员来说也很有帮助。Java中有一个很有效的ArrayList类(读者可以结...
  • xidiangejun
  • xidiangejun
  • 2010年04月20日 13:59
  • 7501

关于java和.net中string string[] arraylist的相互转化

关于string string[] arraylist的相互转换 arraylist转string[] arraylist list=new arraylist(); list.add("aa"...
  • zhangxiaomin1992
  • zhangxiaomin1992
  • 2015年09月16日 15:01
  • 2523

ArrayList转换为字符串

ArrayListString> list = new ArrayListString>(); list.add("one"); list.add("two"); list.add("three");...
  • zhalcie2011
  • zhalcie2011
  • 2017年12月11日 11:08
  • 146

android ArrayList<String> 转 String[]

String[] labels = (String[]) xLabels.toArray(new String[xLabels.size()]);
  • tangweiguo0305
  • tangweiguo0305
  • 2017年10月30日 11:16
  • 161

如何将String类型的数组转换成ArrayList(How to convert a string array to arraylist)

今天看到一篇有趣的外国文章,总结了一下将各个人的发表的意见汇了一下总,姑且当做原创了。 package org.donkey.app.ListToArrayList; import java....
  • W1053288979
  • W1053288979
  • 2013年11月24日 11:12
  • 19454
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:ArrayList readCSV(String filepath)
举报原因:
原因补充:

(最多只允许输入30个字)