• 生成.txt文件
  • 生成.csv文件
  • 生成.xls文件
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStreamWriter;
import java.io.PrintWriter;
import java.text.NumberFormat;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Iterator;
import java.util.List; import org.apache.poi.xssf.usermodel.XSSFCell;
import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook; public class CreateFileUtil { /**
* 生成.TXT格式文件,行数几乎无上限
*/
public static boolean createTxtFile(List<Object[]> rows, String filePath, String fileName) {
// 标记文件生成是否成功
boolean flag = true; try {
// 含文件名的全路径
String fullPath = filePath + File.separator + fileName + ".txt"; File file = new File(fullPath);
if (file.exists()) { // 如果已存在,删除旧文件
file.delete();
}
file = new File(fullPath);
file.createNewFile(); // 格式化浮点数据
NumberFormat formatter = NumberFormat.getNumberInstance();
formatter.setMaximumFractionDigits(10); // 设置最大小数位为10 // 格式化日期数据
SimpleDateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss"); // 遍历输出每行
PrintWriter pfp = new PrintWriter(file, "UTF-8"); //设置输出文件的编码为utf-8
for (Object[] rowData : rows) {
StringBuffer thisLine = new StringBuffer("");
for (int i = 0; i < rowData.length; i++) {
Object obj = rowData[i]; // 当前字段 // 格式化数据
String field = "";
if (null != obj) {
if (obj.getClass() == String.class) { // 如果是字符串
field = (String) obj;
} else if (obj.getClass() == Double.class || obj.getClass() == Float.class) { // 如果是浮点型
field = formatter.format(obj); // 格式化浮点数,使浮点数不以科学计数法输出
} else if (obj.getClass() == Integer.class || obj.getClass() == Long.class
|| obj.getClass() == Short.class || obj.getClass() == Byte.class) { // 如果是整形
field += obj;
} else if (obj.getClass() == Date.class) { // 如果是日期类型
field = sdf.format(obj);
}
} else {
field = " "; // null时给一个空格占位
} // 拼接所有字段为一行数据,用tab键分隔
if (i < rowData.length - 1) { // 不是最后一个元素
thisLine.append(field).append("\t");
} else { // 是最后一个元素
thisLine.append(field);
}
}
pfp.print(thisLine.toString() + "\n");
}
pfp.close(); } catch (Exception e) {
flag = false;
e.printStackTrace();
}
return flag;
} /**
* 生成.csv格式文件,行数几乎无上限
*/
public static boolean createCsvFile(List<Object[]> rows, String filePath, String fileName) {
// 标记文件生成是否成功
boolean flag = true; // 文件输出流
BufferedWriter fileOutputStream = null; try {
// 含文件名的全路径
String fullPath = filePath + File.separator + fileName + ".csv"; File file = new File(fullPath);
if (!file.getParentFile().exists()) { // 如果父目录不存在,创建父目录
file.getParentFile().mkdirs();
}
if (file.exists()) { // 如果已存在,删除旧文件
file.delete();
}
file = new File(fullPath);
file.createNewFile(); // 格式化浮点数据
NumberFormat formatter = NumberFormat.getNumberInstance();
formatter.setMaximumFractionDigits(10); // 设置最大小数位为10 // 格式化日期数据
SimpleDateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss"); // 实例化文件输出流
fileOutputStream = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(file), "GB2312"), 1024); // 遍历输出每行
Iterator<Object[]> ite = rows.iterator();
while (ite.hasNext()) {
Object[] rowData = (Object[]) ite.next();
for (int i = 0; i < rowData.length; i++) {
Object obj = rowData[i]; // 当前字段
// 格式化数据
String field = "";
if (null != obj) {
if (obj.getClass() == String.class) { // 如果是字符串
field = (String) obj;
} else if (obj.getClass() == Double.class || obj.getClass() == Float.class) { // 如果是浮点型
field = formatter.format(obj); // 格式化浮点数,使浮点数不以科学计数法输出
} else if (obj.getClass() == Integer.class || obj.getClass() == Long.class
|| obj.getClass() == Short.class || obj.getClass() == Byte.class) { // 如果是整形
field += obj;
} else if (obj.getClass() == Date.class) { // 如果是日期类型
field = sdf.format(obj);
}
} else {
field = " "; // null时给一个空格占位
}
// 拼接所有字段为一行数据
if (i < rowData.length - 1) { // 不是最后一个元素
fileOutputStream.write("\"" + field + "\"" + ",");
} else { // 是最后一个元素
fileOutputStream.write("\"" + field + "\"");
}
}
// 创建一个新行
if (ite.hasNext()) {
fileOutputStream.newLine();
}
}
fileOutputStream.flush();
} catch (Exception e) {
flag = false;
e.printStackTrace();
} finally {
try {
fileOutputStream.close();
} catch (IOException e) {
e.printStackTrace();
}
}
return flag;
} /**
* 生成.xls格式文件,单页上限: 03版是65536行 ,07版的是1048576行, 10版不知
*/
public static boolean createXlsFile(List<Object[]> rows, String filePath, String fileName) {
// 标记文件生成是否成功
boolean flag = true; try {
// 创建一个webbook,对应一个Excel文件
XSSFWorkbook wb = new XSSFWorkbook(); // 在webbook中添加一个sheet,对应Excel文件中的sheet
XSSFSheet sheet = wb.createSheet(fileName); // 遍历输出每行
for (int i = 0; i < rows.size(); i++) {
Object[] rowData = rows.get(i); // 每一行的数据
XSSFRow row = sheet.createRow(i);
for (int j = 0; j < rowData.length; j++) {
XSSFCell cell = row.createCell(j);
// 假设只有三种类型的数据
if (rowData[j].getClass() == String.class) { // String类型数值
cell.setCellValue((String) rowData[j]);
} else if (rowData[j].getClass() == double.class) { // double类型数值
cell.setCellValue((Double) rowData[j]);
} else if (rowData[j].getClass() == int.class) { // int类型数值
cell.setCellValue((Integer) rowData[j]);
}
}
} String fullPath = filePath + File.separator + fileName + ".xls";// 含文件名的全路径
            File file = new File(fullPath);
if (!file.getParentFile().exists()) { // 如果父目录不存在,创建父目录
file.getParentFile().mkdirs();
}
if (file.exists()) { // 如果已存在,删除旧文件
file.delete();
}
file = new File(fullPath);
file.createNewFile();
            FileOutputStream fileOut = new FileOutputStream(file); // 写出数据到文件
wb.write(fileOut);
fileOut.close();
} catch (Exception e) {
flag = false;
e.printStackTrace();
} return flag;
} }

最新文章

  1. 微信小程序小技巧系列《二》show内容展示,上传文件编码问题
  2. C++控制台贪吃蛇代码
  3. 洛谷 P1449 后缀表达式 Label:表达式计算系列
  4. cocos2d::Vector
  5. Unofficial Windows Binaries for Python Extension Packages
  6. MYSQL中replace into的用法以及与inset into的区别
  7. C++类(一)
  8. Android线程池的使用(未完)
  9. 利用putty实现文件在linux上传和下载
  10. Android开发之发送短信
  11. 蓝桥杯 BASIC 24 龟兔赛跑预測(模拟)
  12. PHP.INI常用设置一览表(持续更新)
  13. android:editable is deprecated: Use an &lt;EditText&gt; to make it editable
  14. editplus和ultraedit(UE)的使用
  15. 在Spring Boot中使用数据库事务
  16. Git日常须知
  17. 手把手教你提交文件到git
  18. _event_phase
  19. Java实验报告(实验二)
  20. Python threadpool传递参数

热门文章

  1. Java动态 遍历List 时删除List特征元素 异常问题 及解决方案总结
  2. OJ2.0userInfo页面Modify逻辑bug修复,search功能逻辑实现
  3. IOS 设备信息读取
  4. HDU 1085 Holding Bin-Laden Captive! (母函数)
  5. LabView 下载与安装
  6. SQLLoader8(加载的数据中有换行符处理方法)
  7. simplify the life ECMAScript 5(ES5)中bind方法简介
  8. Oracle - 找不到原因的无效字符
  9. ArcGIS10.3.1于2015年6月发布
  10. 13年山东省赛 Mountain Subsequences(dp)