成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

淺談Java讀取Csv實踐

開發 后端
Csv文件,逗號分隔的常用數據文件格式,默認可以用Office軟件打開。

Csv文件,逗號分隔的常用數據文件格式,默認可以用Office軟件打開。

維基百科對CSV的詳細描述:

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

看項目中以前的處理方式是直接用用java IO類庫讀取Csv文件,實際處理中發現Csv文件本身包含了對各種特殊字符的處理信息。最常見的比如:

1. 對包含特殊字符的字符串數據首尾加雙引號

2. 對數據中的單個雙引號前加單個雙引號

其它...

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

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

代碼很簡單:

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.                 //讀取每行數據以數組形式返回     
  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.                 //關閉CsvReader     
  24.                 reader.close();     
  25.         }     
  26.         return list;     
  27.     }   

 

以上代碼有幾個要點:

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

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

3 ***記得關閉CsvReader

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

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

附javacvs2.0.zip鏈接:http://shaka.iteye.com/blog/983282

【編輯推薦】

  1. Java 7路線圖更新 未包含閉包特性
  2. Java 7.0中值得期待的新功能預覽
  3. Java程序開發中的簡單內存分析
  4. 2009年十大Java技術解決方案
  5. 2008最值得學習的五種JAVA技術
責任編輯:金賀 來源: ITEYE博客
相關推薦

2011-04-15 14:37:45

JavaCsv

2017-11-10 13:02:44

iOSUI代碼

2009-07-09 14:56:23

Servlet讀取

2016-08-31 09:58:55

JavascriptFlux架構

2023-06-12 15:43:44

鴻蒙智能家居開發

2009-08-20 09:41:36

2018-08-29 13:57:40

前端性能測試Html5

2021-07-28 13:29:57

大數據PandasCSV

2010-02-01 13:26:58

C++讀取CSV文件

2023-12-05 13:47:00

Java開發

2009-08-21 11:02:55

C#異步調用

2024-10-23 21:21:32

2022-12-14 10:09:44

研發效能

2011-07-28 18:11:18

Objective-C Cocoa 編程

2015-01-15 17:41:54

soa云計算BPEL

2023-03-28 07:42:03

2019-01-02 13:45:19

2024-06-25 09:08:24

.NETCSV文件

2025-02-17 01:00:00

.NET性能服務器

2011-05-26 15:33:29

volatilejava
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 成人在线一级片 | 久久久久se| 99久久精品免费看国产四区 | 成人精品免费视频 | 在线观看中文字幕亚洲 | 黄色免费在线观看网站 | 欧美精品在线免费观看 | 国产精品福利在线观看 | av黄色网 | 午夜丰满少妇一级毛片 | 国产一区二区自拍 | 激情五月婷婷综合 | 久久成人一区 | 国产免费一区二区三区免费视频 | 亚洲一区二区三区在线视频 | 久久极品| 精品视频一区二区三区在线观看 | 黑人巨大精品欧美一区二区免费 | 日韩精品在线播放 | 91国产视频在线观看 | 国产精品夜间视频香蕉 | 亚洲一区视频在线 | 国产精品久久九九 | 欧美日韩国产中文字幕 | av大全在线观看 | 日韩在线观看网站 | 国产精品嫩草影院精东 | 久久精品一区二区三区四区 | 一区二区在线观看av | 天天躁日日躁性色aⅴ电影 免费在线观看成年人视频 国产欧美精品 | 久久久av中文字幕 | 成人黄色av网址 | 国产精品久久久久久久久久三级 | 亚洲五码久久 | 在线免费观看黄色 | 欧美一区二区三区在线播放 | 一区二区三区在线观看视频 | 日韩日b视频 | 天天草视频 | 成人久草 | 日本不卡免费新一二三区 |