本文目錄一覽:
java如何導出csv文件 用戶點擊導出可以導出到他想保存的地方
這種通常是如下做法:
1:提供查詢頁面,讓用戶輸入查詢條件
2:根據查詢條件到資料庫去檢索,並獲取到對應的記錄
3:生成csv到本地(可以省略,生成臨時文件到tomcat的臨時目錄)
4:用讀取文件,用response寫流到客戶端
java導出csv如何避免內存溢出
Java調用一下shell腳本,用shell腳本去執行導出CSV到一個文件夾,然後再下載,完事,因為用其它方式導出會更加高效,內存和速度都很快。
用java導出.csv格式的文件
使用poi包,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();
}
}
原創文章,作者:ABLV,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/149256.html