java語言

當前位置 /首頁/計算機/java語言/列表

java讀取CSV的方法

專案開發中,我們經常需要讀取csv的內容的操作。讀取的邏輯並不複雜。以下是小編為大家搜尋整理的java讀取CSV的方法,希望能給大家帶來幫助!更多精彩內容請及時關注我們應屆畢業生考試網!

java讀取CSV的方法

Csv檔案,逗號分隔的常用資料檔案格式,預設可以用Office軟體開啟。

看專案中以前的處理方式是直接用用java IO類庫讀取Csv檔案,實際處理中發現Csv檔案本身包含了對各種特殊字元的處理資訊。最常見的比如:

1. 對包含特殊字元的字串資料首尾加雙引號

2. 對資料中的單個雙引號前加單個雙引號

其它...

所以用Java IO讀到的字串全是經過處理後的字串,在某些場景下是不符合預期需求的。比如我需要的是不做任何處理的原始內容。

專案中另一種常見的檔案格式Excel用了POI來處理,但是POI不支援Csv格式,於是找到了javacsv。

程式碼很簡單:

Java程式碼

public List importCsv(String file) {

List list = new ArrayList();

CsvReader reader = null;

try {

//初始化CsvReader並指定列分隔符和字元編碼

reader = new CsvReader(file, ',', ame("GBK"));

while (Record()) {

//讀取每行資料以陣列形式返回

String[] str = alues();

if (str != null && th > 0) {

if (str[0] != null && !""ls(str[0]())) {

(str);

}

}

}

} catch (FileNotFoundException e) {

r("Error reading csv file.",e);

} catch (IOException e) {

r("",e);

}

finally{

if(reader != null)

//關閉CsvReader

e();

}

return list;

}

以上程式碼有幾個要點:

1 初始化CsvReader時指定分隔符和字元編碼,如果不指定,預設分別為逗號和ISO-8859-1,我用了GBK,具體使用時要看當時的字元編碼而定。

2 讀取每行資料,返回字串陣列,陣列內的順序即檔案資料列的`順序

3 最後記得關閉CsvReader

是不是很簡單,返回的陣列格式也正好是我想要的,而且拿到是原始的資料,沒有經過特殊字元處理。

有些童鞋質疑特殊字元未經處理,插到資料庫會出錯,其實大可不必我們手工處理,一些基礎元件比如JDBC的preparedstatement已經包含了對特殊字元的處理,我們只要以繫結引數的形式來傳送這些包含特殊字元的資料就可以。常用的持久化框架底層也封裝了JDBC,自然也對特殊字元做了處理。

TAG標籤:CSV 讀取 JAVA #