java讀取CSV的方法大全
【提要】本篇《java讀取CSV的方法》特別為需要方法編程學習的朋友收集整理的,僅供參考。內容如下:
在項目開發中,我們經常需要讀取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,自然也對特殊字符做了處理。
-
計算機二級Java備考習題及答案
練習可以幫助我們加深對知識的記憶和理解,下面是本站小編整理的2017計算機二級Java備考練習題及答案,歡迎學習!備考練習題一1、下列敍述中,錯誤的是______。A、Applet的默認佈局管理器是FlowLayoutB、JApplet中增加構件是加到JApplet的內容面板上,不是直接加到JApp...
-
Java中運算符的使用
導語:計算機的最基本用途之一就是執行數學運算,作為一門計算機語言,Java也提供了一套豐富的運算符來操縱變量。下面是java中運算符的使用,一起來學習下吧:算術運算符單目:+(取正)-(取負)++(自增1)--(自減1)雙目:+-*/%(取餘)三目:a>b?true:false説明:當a大於b的時候,為tru...
-
Java創建線程的三種方法
導語:編寫多線程程序是為了實現多任務的併發執行,從而能夠更好地與用户交互。下面是Java創建線程的三種方法,一起來學習下吧:Runnable和Callable的區別(1)Callable規定的方法是call(),Runnable規定的方法是run().(2)Callable的任務執行後可返回值,而Runnable的任務...
-
java與JavaScript語言有何不同
java和JavaScript是兩個不同的語言。那麼這兩個語言有什麼不同呢?下面本站小編帶大家一起來看看詳細內容,希望對大家有所幫助!想了解更多相關信息請持續關注我們應屆畢業生考試網!講個故事:話説很久很久以前,有一個叫網景(Netscape)的,十月懷胎,他生了個兒子,很開興,...