用java的poi类读取一个excel表格的内容后再写入到一个新excel表格中的完整代码

是一个c/s程序 在本地读取后再保存到本地 excel数据量大

读取一个excel内容,然后整合一下里面数据,然后再生成一个新的excel吧。

package aa;

import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.InputStream;

import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.poifs.filesystem.POIFSFileSystem;

//你是想读取一个excel内容,然后整合一下里面数据,然后再生成一个新的excel吧。

public class A {

    public static void main(String[] args) throws Exception{

        //读取excel:
        InputStream is = new FileInputStream("d:\\test2.xls");
        POIFSFileSystem fs = new POIFSFileSystem(is);
        HSSFWorkbook wb = new HSSFWorkbook(fs);

        //读取sheet,读取sheet里面第一行第一列内容
        HSSFSheet sheet = wb.getSheetAt(0);
        HSSFRow  row = sheet.getRow(0);
        HSSFCell cell = row.getCell((short) 0);
        String  s = cell.getStringCellValue();

        System.out.println(s);

        //...内容组合自己玩~

        //比如上面组合好了一个String  S2

        //写入一个excel  比如 test3.xls
        FileOutputStream fos = new FileOutputStream("d:\\test3.xls");

            HSSFWorkbook wb2 = new HSSFWorkbook();
            HSSFSheet hsSheet = wb2.createSheet("TestReport");
            HSSFRow hsRow1 = hsSheet.createRow(0);//建行
            hsRow1.setHeight((short) 500);
            HSSFCell hsCell11 = hsRow1.createCell((short) 0);
            hsCell11.setEncoding(HSSFCell.ENCODING_UTF_16);
            hsCell11.setCellValue(s+"TESTVALUE");
            wb2.write(fos);
            fos.close();
    }
}
好的,这是一个技术问题,我可以回答。您可以使用Apache的POI库来访问和更Excel文件。以下是一个简单的Java代码示例,用于读取Excel文件的数据并将其写入文件。 ```java import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import java.util.Iterator; 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.WorkbookFactory; import org.apache.poi.xssf.usermodel.XSSFWorkbook; public class ExcelReaderWriter { public static void main(String[] args) { try (FileInputStream file = new FileInputStream(new File("existing_excel.xlsx")); XSSFWorkbook workbook = (XSSFWorkbook) WorkbookFactory.create(file); FileOutputStream out = new FileOutputStream(new File("new_excel.xlsx"))) { // Get first/desired sheet from the workbook Sheet sheet = workbook.getSheetAt(0); // Iterate through each rows one by one Iterator<Row> rowIterator = sheet.iterator(); while (rowIterator.hasNext()) { Row row = rowIterator.next(); // For each row, iterate through all the columns Iterator<Cell> cellIterator = row.cellIterator(); while (cellIterator.hasNext()) { Cell cell = cellIterator.next(); // Check the cell type and format accordingly switch (cell.getCellType()) { case NUMERIC: System.out.print(cell.getNumericCellValue() + "t"); break; case STRING: System.out.print(cell.getStringCellValue() + "t"); break; } } System.out.println(""); } // Write the output to a file workbook.write(out); out.close(); } catch (IOException e) { e.printStackTrace(); } } } ``` 在这个例子,我们首先打开一个已经存在的Excel文件,然后使用POI库获取第一个Sheet。我们遍历每一行和每个单元格,并根据单元格的型进行格式化。最后,我们将更后的数据写入一个Excel文件
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值