91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java是怎樣讀取CSV的

發布時間:2021-11-30 15:54:43 來源:億速云 閱讀:181 作者:小新 欄目:編程語言

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

看項目中以前的處理方式是直接用用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, ',', Charset.forName("GBK"));  while (reader.readRecord())   {  //讀取每行數據以數組形式返回  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)  //關閉CsvReader  reader.close();  }  return list;  }

以上代碼有幾個要點:

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

2 讀取每行數據,返回字符串數組,數組內的順序即文件數據列的順序

3 ***記得關閉CsvReader

是不是很簡單,返回的數組格式也正好是我想要的,而且拿到是原始的數據,沒有經過特殊字符處理。

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

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

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

读书| 老河口市| 普安县| 德兴市| 赤水市| 石台县| 克山县| 文成县| 昆山市| 永昌县| 勐海县| 瑞金市| 洛川县| 个旧市| 揭阳市| 潮州市| 外汇| 安福县| 民乐县| 大兴区| 南通市| 武城县| 孟津县| 金堂县| 普格县| 大渡口区| 安塞县| 富平县| 万盛区| 宜城市| 呼玛县| 永安市| 阿鲁科尔沁旗| 吉安县| 肇源县| 安泽县| 楚雄市| 舟山市| 太谷县| 叶城县| 上高县|