java讀寫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;
 
public class OperateCSVfile {
    public static void main(String[] args){
        String [] str = {"省","市","區","街","路","里","幢","村","室","園","苑","巷","號"};
        File inFile = new File("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;
 
public class OperateCSVfile {
    public static void main(String[] args){
        String [] str = {"省","市","區","街","路","里","幢","村","室","園","苑","巷","號"};
        File inFile = new File("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文件的兩種方法 - 水到絕境是飛瀑 - if(生命==不息) then 奮發如松
 
java讀寫CSV文件的兩種方法 - 水到絕境是飛瀑 - if(生命==不息) then 奮發如松
 
之 后我又在網上查了一下資料,發現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; 
 
public class readandwrite {
    public static void main(String[] args) throws IOException { 
        String [] str = {"省","市","區","街","路","里","幢","村","室","園","苑","巷","號"};
        String inString = "";
        String tmpString = "";
        File inFile = new File("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();
        }
    }
}
得到同樣的效果。
 
-------------------------------------------------------小路原創,轉載請注明出處!--------------------------------------------


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2026 CODEPRJ.COM