日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
淺談Java讀取Csv實(shí)踐

Csv文件,逗號(hào)分隔的常用數(shù)據(jù)文件格式,默認(rèn)可以用Office軟件打開(kāi)。

網(wǎng)站建設(shè)公司,為您提供網(wǎng)站建設(shè),網(wǎng)站制作,網(wǎng)頁(yè)設(shè)計(jì)及定制網(wǎng)站建設(shè)服務(wù),專注于成都定制網(wǎng)頁(yè)設(shè)計(jì),高端網(wǎng)頁(yè)制作,對(duì)陽(yáng)臺(tái)護(hù)欄等多個(gè)行業(yè)擁有豐富的網(wǎng)站建設(shè)經(jīng)驗(yàn)的網(wǎng)站建設(shè)公司。專業(yè)網(wǎng)站設(shè)計(jì),網(wǎng)站優(yōu)化推廣哪家好,專業(yè)營(yíng)銷推廣優(yōu)化,H5建站,響應(yīng)式網(wǎng)站。

維基百科對(duì)CSV的詳細(xì)描述:

http://zh.wikipedia.org/wiki/CSV

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

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

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

其它...

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

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

代碼很簡(jiǎn)單:

Java代碼

 
 
 
  1. public List  importCsv(String file) {     
  2.         List  list =  new ArrayList ();     
  3.         CsvReader reader = null;     
  4.         try {     
  5.             //初始化CsvReader并指定列分隔符和字符編碼     
  6.             reader = new CsvReader(file, ',', Charset.forName("GBK"));     
  7.             while (reader.readRecord()) {     
  8.                 //讀取每行數(shù)據(jù)以數(shù)組形式返回     
  9.                 String[] str = reader.getValues();       
  10.                 if (str != null && str.length > 0) {     
  11.                     if (str[0] != null && !"".equals(str[0].trim())) {     
  12.                         list.add(str);     
  13.                     }     
  14.                 }     
  15.             }     
  16.         } catch (FileNotFoundException e) {     
  17.             log.error("Error reading csv file.",e);     
  18.         } catch (IOException e) {     
  19.             log.error("",e);     
  20.         }     
  21.         finally{     
  22.             if(reader != null)     
  23.                 //關(guān)閉CsvReader     
  24.                 reader.close();     
  25.         }     
  26.         return list;     
  27.     }   

以上代碼有幾個(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ù),沒(méi)有經(jīng)過(guò)特殊字符處理。

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

附j(luò)avacvs2.0.zip鏈接:http://shaka.iteye.com/blog/983282

【編輯推薦】

  1. Java 7路線圖更新 未包含閉包特性
  2. Java 7.0中值得期待的新功能預(yù)覽
  3. Java程序開(kāi)發(fā)中的簡(jiǎn)單內(nèi)存分析
  4. 2009年十大Java技術(shù)解決方案
  5. 2008最值得學(xué)習(xí)的五種JAVA技術(shù)

當(dāng)前標(biāo)題:淺談Java讀取Csv實(shí)踐
文章來(lái)源:http://www.dlmjj.cn/article/dpcdgjd.html