1. 程式人生 > >java讀寫CSV檔案的兩種方法

java讀寫CSV檔案的兩種方法

BufferedWriter writer =new BufferedWriter(new OutputStreamWriter(new FileOutputStream(outFile), "GBK")) ;// 附加 

上述程式碼片段作用: 轉碼

逗號分隔值(Comma-Separated Values,CSV,有時也稱為字元分隔值,因為分隔字

符也可以不是逗號),其檔案以純文字形式儲存表格資料(數字和文字)。

起初,我自己連什麼叫CSV檔案都不知道,這個問題是來自一個網友的問題,他要我幫他做一個對csv檔案資料的操作的題目。要求:如果原來資料是“江蘇省南京市南京街……”換成“江蘇  省  南京  市   南京  街  ……”也就是把出現類似"省","市","區","街","路","裡","幢","村","室","園","苑","巷","號"的都在其前面和後面都加上空格。根據他給的一個參考文件做了一下,第一次做的雖然實現了功能,但是程式碼比較累贅,之後看了一下String類的一些方法,發現有一個replace(str,str)方法可以很快替換掉原來字串中的字元,就對原來的方法進行了修改,程式碼顯得少了很多。

    CSV檔案簡介:Comma Separated Values,簡稱CSV,即逗號分隔值,是一種純文字格式,用來儲存資料。在CSV中,資料的欄位由逗號分開。CSV檔案是一個計算機資料檔案用於執行審判和真正的組織工具,逗號分隔的清單。常常被用於移動表格資料之間的兩個不同的計算機程式,例如關係資料庫程式和電子表格程式。建議用記事本新建一個檔案然後修改後綴名,也建議用記事本開啟CSV檔案。用Excel開啟,有時候會報錯。     下面是最開始寫的比較累贅的程式碼: package test;import java.io.BufferedReader;import java.io.BufferedWriter
;import java.io.File;import java.io.FileNotFoundException;import java.io.FileReader;import java.io.FileWriter;import java.io.IOException;
publicclassOperateCSVfile{publicstaticvoid main(String[] args){String[] str ={"省","市","區","街","路","裡","幢","村","室","園","苑","巷","號"};File inFile =newFile("C://in.csv");
// 讀取的CSV檔案        File outFile = new File("C://out.csv");//寫出的CSV檔案        String inString = "";        String tmpString = "";        try {            BufferedReader reader = new BufferedReader(new FileReader(inFile));            BufferedWriter writer = new BufferedWriter(new FileWriter(outFile));            while((inString = reader.readLine())!= null){                char [] c = inString.toCharArray();                String [] value = new String[c.length];                String result = "";                for(int i = 0;i < c.length;i++){                    value[i] = String.valueOf(c[i]);                    for(int j = 0;j < str.length;j++){                        if(value[i].equals(str[j])){                            String tmp = value[i];                            value[i] = "," + tmp + ",";                        }                    }                    result += value[i];                }               writer.write(inString);               writer.newLine();            }            reader.close();            writer.close();        } catch (FileNotFoundException ex) {            System.out.println("沒找到檔案!");        } catch (IOException ex) {            System.out.println("讀寫檔案出錯!");        }    }} 利用String類的replace()方法之後的程式碼簡化為; package test;import java.io.BufferedReader;import java.io.BufferedWriter;import java.io.File;import java.io.FileNotFoundException;import java.io.FileReader;import java.io.FileWriter;import java.io.IOException;publicclassOperateCSVfile{publicstaticvoid main(String[] args){String[] str ={"省","市","區","街","路","裡","幢","村","室","園","苑","巷","號"};File inFile =newFile("C://in.csv");// 讀取的CSV檔案        File outFile = new File("C://out.csv");//寫出的CSV檔案        String inString = "";        String tmpString = "";        try {            BufferedReader reader = new BufferedReader(new FileReader(inFile));            BufferedWriter writer = new BufferedWriter(new FileWriter(outFile));            while((inString = reader.readLine())!= null){                for(int i = 0;i<str.length;i++){                    tmpString = inString.replace(str[i], "," + str[i] + ",");                    inString = tmpString;                }
               writer.write(inString);               writer.newLine();}            reader.close();            writer.close();}catch(FileNotFoundException ex){System.out.println("沒找到檔案!");}catch(IOException ex){System.out.println("讀寫檔案出錯!");}}} 效果圖; 之後我又在網上查了一下資料,發現java有專門操作CSV檔案的類和方法。java開源框架csvreader提供了一個輕量級的、簡單方便的統一操作介面可用。要使用CsvReader,CsvWriter需要下載一個javacsv.jar匯入到專案中才行,在專案上點選右鍵--屬性--庫--新增jar檔案,選擇javacsv.jar檔案即可,然後在程式中用import com.csvreader.CsvReader,import  com.csvreader.CsvWriter匯入即可。

程式碼如下: 
package test;import com.csvreader.CsvReader;import com.csvreader.CsvWriter;import java.io.BufferedReader;import java.io.BufferedWriter;import java.io.File;import java.io.FileNotFoundException;import java.io.FileReader;import java.io.FileWriter;import java.io.IOException;publicclass readandwrite {publicstaticvoid main(String[] args)throwsIOException{String[] str ={"省","市","區","街","路","裡","幢","村","室","園","苑","巷","號"};String inString ="";String tmpString ="";File inFile =newFile("C://in.csv");// 讀取的CSV檔案        File outFile = new File("C://outtest.csv");//輸出的CSV文        try {            BufferedReader reader = new BufferedReader(new FileReader(inFile));            BufferedWriter writer = new BufferedWriter(new FileWriter(outFile));            CsvReader creader = new CsvReader(reader, ',');            CsvWriter cwriter = new CsvWriter(writer,',');            while(creader.readRecord()){                inString = creader.getRawRecord();//讀取一行資料                for(int i = 0;i < str.length;i++){                    tmpString = inString.replace(str[i], "," + str[i] + ",");                    inString = tmpString;                }                //第一個引數表示要寫入的字串陣列,每一個元素佔一個單元格,第二個引數為true時表示寫完資料後自動換行            cwriter.writeRecord(inString.split(","), true);            //注意,此時再用cwriter.write(inString)方法寫入資料將會看到只往第一個單元格寫入了資料,“,”沒起到調到下一個單元格的作用            //如果用cwriter.write(String str)方法來寫資料,則要用cwriter.endRecord()方法來實現換行            //cwriter.endRecord();//換行            cwriter.flush();//重新整理資料            }              creader.close();            cwriter.close();        } catch (FileNotFoundException ex) {            ex.printStackTrace();        }    }} 得到同樣的效果。