java读取csv存入list_用JAVA读取CSV文件格式,存入List 中,其每个元素为一个String[]...

该博客介绍了如何使用Java从CSV文件中读取数据,并将每行内容存储为一个String数组,放入List中。通过处理特殊字符和使用正则表达式进行拆分,实现了对包含逗号和双引号的复杂CSV数据的解析。
摘要由CSDN通过智能技术生成

package dong.csv;

import java.io.BufferedReader;

import java.io.File;

import java.io.FileNotFoundException;

import java.io.FileReader;

import java.io.IOException;

import java.util.ArrayList;

import java.util.Arrays;

import java.util.List;

import java.util.regex.Matcher;

import java.util.regex.Pattern;

public class CSVParser {

private File file;

private List resultList = new ArrayList();

private static Pattern pattern = Pattern

.compile(",?\"([^\"]*(\"{2}[^\"]*\"{2}[^\"]*)*)\",?");

public static void main(String[] args) {

CSVParser parser = new CSVParser("test.csv");

List list = parser.parse();

print(list);

}

public CSVParser(File file) {

this.file = file;

}

public CSVParser(String filePath) {

file = new File(filePath);

}

private static void print(List list) {

for (int i = 0; i < list.size(); i++)

System.out.println(Arrays.toString(list.get(i)) + " Length: "

+ list.get(i).length);

}

public List parse() {

try {

BufferedReader br = getReader();

String line = "";

while ((line = br.readLine()) != null) {

line = handleSpecial(line);

String[] elements = line.split(",");

revert(elements);

store(elements);

}

} catch (FileNotFoundException e) {

e.printStackTrace();

} catch (IOException e) {

e.printStackTrace();

}

return resultList;

}

/**

* Revert to original ',' if contains '|', precondition is that each

* original Field of the line doesn't contain this char

*

* @param elements

*/

private void revert(String[] elements) {

for (int i = 0; i < elements.length; i++)

elements[i] = elements[i].replace("|", ",");

}

private void store(String[] elements) {

resultList.add(elements);

}

private BufferedReader getReader() {

BufferedReader br = null;

try {

//br = new BufferedReader(new InputStreamReader(new FileInputStream(

//file), Charset.forName("GB18030")));// ISO-8859-1,GB18030

br = new BufferedReader(new FileReader(file));

} catch (FileNotFoundException e) {

e.printStackTrace();

}

return br;

}

/**

* Handling special characters for each given line.

*

* @param inputLine

* @return

*/

private String handleSpecial(String inputLine) {

if (inputLine == null || inputLine.trim().length() == 0)

return "";

Matcher m = getMatcher(inputLine);

String after = "";

while (m.find()) {

after = m.group(2);

String before = after;

System.out.println("Before: " + before);

if (after.indexOf(",") > -1)

// use '|' to replace ',' for later splitting of each field of

// the line,this '|' needs to be revert to ',' after the whole line being

// split

after = after.replace(',', '|');

if (after.indexOf("\"\"") > -1)

after = after.replace("\"\"", "\"");

System.out.println("After:" + after);

inputLine = inputLine.replace(before, after);

}

return inputLine;

}

private static Matcher getMatcher(String sequence) {

return pattern.matcher(sequence);

}

}

下载次数: 74

1

0

分享到:

18e900b8666ce6f233d25ec02f95ee59.png

72dd548719f0ace4d5f9bca64e1d7715.png

2011-05-14 12:47

浏览 9599

评论

1 楼

economist

2012-08-16

38687d1a1ad71d37c86f287056834d1a.gif

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值