java導出csv文件實例程序(前端導出csv文件)

本文目錄一覽:

java將查詢數據導出成csv文件的問題

解釋:csv文件實際上就是字符串,之間用「,」進行分割,之後進行的存儲。

工具類如下:

import java.io.BufferedWriter;

import java.io.File;

import java.io.FileOutputStream;

import java.io.IOException;

import java.io.OutputStreamWriter;

import java.util.List;

/**

*

* CSV文件導出工具類

*/

public class CSVUtils {

/**

* CSV文件生成方法

* @param head

* @param dataList

* @param outPutPath

* @param filename

* @return

*/

public static File createCSVFile(ListObject head, ListListObject dataList,

String outPutPath, String filename) {

File csvFile = null;

BufferedWriter csvWtriter = null;

try {

csvFile = new File(outPutPath + File.separator + filename + “.csv”);

File parent = csvFile.getParentFile();

if (parent != null !parent.exists()) {

parent.mkdirs();

}

csvFile.createNewFile();

// GB2312使正確讀取分隔符”,”

csvWtriter = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(

csvFile), “GB2312”), 1024);

// 寫入文件頭部

writeRow(head, csvWtriter);

// 寫入文件內容

for (ListObject row : dataList) {

writeRow(row, csvWtriter);

}

csvWtriter.flush();

} catch (Exception e) {

e.printStackTrace();

} finally {

try {

csvWtriter.close();

} catch (IOException e) {

e.printStackTrace();

}

}

return csvFile;

}

/**

* 寫一行數據方法

* @param row

* @param csvWriter

* @throws IOException

*/

private static void writeRow(ListObject row, BufferedWriter csvWriter) throws IOException {

// 寫入文件頭部

for (Object data : row) {

StringBuffer sb = new StringBuffer();

String rowStr = sb.append(“\””).append(data).append(“\”,”).toString();

csvWriter.write(rowStr);

}

csvWriter.newLine();

}

}

求個java讀取csv文件並輸出的程序

要使用CsvReader,CsvWriter需要下載一個javacsv.jar導入到項目中 

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();        }    }}

java里將從excel讀到的數據用csv導出,代碼怎麼寫

解釋:csv文件實際上就是字符串,之間用「,」進行分割,之後進行的存儲。

工具類如下:

import java.io.BufferedWriter;

import java.io.File;

import java.io.FileOutputStream;

import java.io.IOException;

import java.io.OutputStreamWriter;

import java.util.List;

/**

*

* CSV文件導出工具類

*/

public class CSVUtils {

/**

* CSV文件生成方法

* @param head

* @param dataList

* @param outPutPath

* @param filename

* @return

*/

public static File createCSVFile(List head, ListList dataList,

String outPutPath, String filename) {

File csvFile = null;

BufferedWriter csvWtriter = null;

try {

csvFile = new File(outPutPath + File.separator + filename + “.csv”);

File parent = csvFile.getParentFile();

if (parent != null !parent.exists()) {

parent.mkdirs();

}

csvFile.createNewFile();

// GB2312使正確讀取分隔符”,”

csvWtriter = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(

csvFile), “GB2312”), 1024);

// 寫入文件頭部

writeRow(head, csvWtriter);

// 寫入文件內容

for (List row : dataList) {

writeRow(row, csvWtriter);

}

csvWtriter.flush();

} catch (Exception e) {

e.printStackTrace();

} finally {

try {

csvWtriter.close();

} catch (IOException e) {

e.printStackTrace();

}

}

return csvFile;

}

/**

* 寫一行數據方法

* @param row

* @param csvWriter

* @throws IOException

*/

private static void writeRow(List row, BufferedWriter csvWriter) throws IOException {

// 寫入文件頭部

for (Object data : row) {

StringBuffer sb = new StringBuffer();

String rowStr = sb.append(“\””).append(data).append(“\”,”).toString();

csvWriter.write(rowStr);

}

csvWriter.newLine();

}

}

Object-Z

java如何導出csv文件 用戶點擊導出可以導出到他想保存的地方

這種通常是如下做法:

1:提供查詢頁面,讓用戶輸入查詢條件

2:根據查詢條件到數據庫去檢索,並獲取到對應的記錄

3:生成csv到本地(可以省略,生成臨時文件到tomcat的臨時目錄)

4:用讀取文件,用response寫流到客戶端

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/278156.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-19 13:21
下一篇 2024-12-19 13:21

相關推薦

發表回復

登錄後才能評論