溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Java是怎樣讀取CSV的

發(fā)布時(shí)間:2021-11-30 15:54:43 來源:億速云 閱讀:173 作者:小新 欄目:編程語(yǔ)言

這篇文章給大家分享的是有關(guān)Java是怎樣讀取CSV的的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過來看看吧。

看項(xiàng)目中以前的處理方式是直接用用java IO類庫(kù)讀取Csv文件,實(shí)際處理中發(fā)現(xiàn)Csv文件本身包含了對(duì)各種特殊字符的處理信息。最常見的比如:

1. 對(duì)包含特殊字符的字符串?dāng)?shù)據(jù)首尾加雙引號(hào)

2. 對(duì)數(shù)據(jù)中的單個(gè)雙引號(hào)前加單個(gè)雙引號(hào)

其它...

所以用Java IO讀到的字符串全是經(jīng)過處理后的字符串,在某些場(chǎng)景下是不符合預(yù)期需求的。比如我需要的是不做任何處理的原始內(nèi)容。

項(xiàng)目中另一種常見的文件格式Excel用了POI來處理,但是POI不支持Csv格式,于是找到了javacsv。

代碼很簡(jiǎn)單:

Java代碼

public List importCsv(String file)   {  List list = new ArrayList();  CsvReader reader = null;  try   {  //初始化CsvReader并指定列分隔符和字符編碼  reader = new CsvReader(file, ',', Charset.forName("GBK"));  while (reader.readRecord())   {  //讀取每行數(shù)據(jù)以數(shù)組形式返回  String[] str = reader.getValues();  if (str != null && str.length > 0)   {  if (str[0] != null && !"".equals(str[0].trim()))   {  list.add(str);  }  }  }  }   catch (FileNotFoundException e) {  log.error("Error reading csv file.",e);  }   catch (IOException e)   {  log.error("",e);  }  finally {  if(reader != null)  //關(guān)閉CsvReader  reader.close();  }  return list;  }

以上代碼有幾個(gè)要點(diǎn):

1 初始化CsvReader時(shí)指定分隔符和字符編碼,如果不指定,默認(rèn)分別為逗號(hào)和ISO-8859-1,我用了GBK,具體使用時(shí)要看當(dāng)時(shí)的字符編碼而定。

2 讀取每行數(shù)據(jù),返回字符串?dāng)?shù)組,數(shù)組內(nèi)的順序即文件數(shù)據(jù)列的順序

3 ***記得關(guān)閉CsvReader

是不是很簡(jiǎn)單,返回的數(shù)組格式也正好是我想要的,而且拿到是原始的數(shù)據(jù),沒有經(jīng)過特殊字符處理。

有些同學(xué)質(zhì)疑特殊字符未經(jīng)處理,插到數(shù)據(jù)庫(kù)會(huì)出錯(cuò),其實(shí)大可不必我們手工處理,一些基礎(chǔ)組件比如JDBC的preparedstatement已經(jīng)包含了對(duì)特殊字符的處理,我們只要以綁定參數(shù)的形式來傳送這些包含特殊字符的數(shù)據(jù)就可以。常用的持久化框架底層也封裝了JDBC,自然也對(duì)特殊字符做了處理。

感謝各位的閱讀!關(guān)于“Java是怎樣讀取CSV的”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI