java批量生成txt文件内容_java实现写大量数据到文件中

这篇博客介绍了如何使用Java批量生成TXT、CSV和XLS格式的文件。通过`CreateFileUtil`类提供的三个静态方法,可以将数据列表转换为文件,包括格式化数据、处理不同类型的数据如日期和浮点数,并且处理了文件重名和编码问题。
摘要由CSDN通过智能技术生成

importjava.io.BufferedWriter;importjava.io.File;importjava.io.FileOutputStream;importjava.io.IOException;importjava.io.OutputStreamWriter;importjava.io.PrintWriter;importjava.text.NumberFormat;importjava.text.SimpleDateFormat;importjava.util.Date;importjava.util.Iterator;importjava.util.List;importorg.apache.poi.xssf.usermodel.XSSFCell;importorg.apache.poi.xssf.usermodel.XSSFRow;importorg.apache.poi.xssf.usermodel.XSSFSheet;importorg.apache.poi.xssf.usermodel.XSSFWorkbook;public classCreateFileUtil {/*** 生成.TXT格式文件,行数几乎无上限*/

public static boolean createTxtFile(Listrows, String filePath, String fileName) {//标记文件生成是否成功

boolean flag = true;try{//含文件名的全路径

String fullPath = filePath + File.separator + fileName + ".txt";

File file= newFile(fullPath);if (file.exists()) { //如果已存在,删除旧文件

file.delete();

}

file= newFile(fullPath);

file.createNewFile();//格式化浮点数据

NumberFormat formatter =NumberFormat.getNumberInstance();

formatter.setMaximumFractionDigits(10); //设置最大小数位为10//格式化日期数据

SimpleDateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");//遍历输出每行

PrintWriter pfp = newPrintWriter(file, "UTF-8"); //设置输出文件的编码为utf-8for(Obj

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用Apache POI库来实现Java的Excel文件操作。以下是一个简单的代码示例,可以批量导入数据生成校验失败数据的Excel文件: ```java import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import java.util.ArrayList; import java.util.Iterator; import java.util.List; import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet; import org.apache.poi.ss.usermodel.Workbook; import org.apache.poi.xssf.usermodel.XSSFWorkbook; public class ExcelImport { public static void main(String[] args) throws IOException { // 读取Excel文件 FileInputStream inputStream = new FileInputStream("input.xlsx"); Workbook workbook = new XSSFWorkbook(inputStream); Sheet sheet = workbook.getSheetAt(0); // 遍历Excel文件数据 Iterator<Row> iterator = sheet.iterator(); List<String[]> validData = new ArrayList<>(); // 保存校验通过的数据 List<String[]> invalidData = new ArrayList<>(); // 保存校验失败的数据 while (iterator.hasNext()) { Row currentRow = iterator.next(); Iterator<Cell> cellIterator = currentRow.iterator(); String[] rowData = new String[currentRow.getLastCellNum()]; boolean valid = true; // 校验标识 while (cellIterator.hasNext()) { Cell currentCell = cellIterator.next(); int columnIndex = currentCell.getColumnIndex(); rowData[columnIndex] = currentCell.getStringCellValue(); // 进行校验,如果校验失败,设置valid为false // ... } if (valid) { validData.add(rowData); } else { invalidData.add(rowData); } } // 生成校验失败的数据的Excel文件 Workbook outputWorkbook = new XSSFWorkbook(); Sheet outputSheet = outputWorkbook.createSheet("Invalid Data"); for (int i = 0; i < invalidData.size(); i++) { Row row = outputSheet.createRow(i); String[] rowData = invalidData.get(i); for (int j = 0; j < rowData.length; j++) { Cell cell = row.createCell(j); cell.setCellValue(rowData[j]); } } FileOutputStream outputStream = new FileOutputStream("output.xlsx"); outputWorkbook.write(outputStream); outputWorkbook.close(); // 关闭文件流 workbook.close(); inputStream.close(); outputStream.close(); } } ``` 在上面的代码,我们首先读取了一个名为“input.xlsx”的Excel文件,并遍历其的所有行和单元格。在遍历过程,我们可以进行数据校验,并将校验通过和校验失败的数据分别保存到`validData`和`invalidData`列表。 接下来,我们创建了一个名为“Invalid Data”的新工作表,并将校验失败的数据入其。最后,我们将新的Excel文件入名为“output.xlsx”的文件,并关闭所有文件流。 请注意,上面的代码示例仅供参考。具体实现方式可能因为实际业务需求而有所不同。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值