Excel Apache POI печатает только последний элемент при выполнении setCellValue () - PullRequest
0 голосов
/ 08 декабря 2018

Я читаю некоторые данные из Excel и записываю их на другой лист в том же файле в виде столбца, и я хочу, чтобы столбец был напечатан в строке.Когда я выполняю итерацию, createRow (). SetCellValue () печатает только последний элемент.

package com.editDistance;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
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.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.ss.util.CellRangeAddress;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

public class ReadColumnsEditDistance {

	public static void main(String[] args) throws IOException {
		// TODO Auto-generated method stub

		File src = new File("C:\\Users\\xyz\\Desktop\\folder\\file.xlsx");
		FileInputStream file = new FileInputStream(src);
		Workbook workbook = new XSSFWorkbook(file);
		Sheet sheet1 = workbook.getSheetAt(0);
		int rows = sheet1.getPhysicalNumberOfRows();
		workbook.createSheet();
		Sheet sheet2 = workbook.getSheetAt(1);
		for (int Readingrowindex = 1; Readingrowindex < rows; Readingrowindex++) {

			String ah = sheet1.getRow(Readingrowindex).getCell(1).getStringCellValue();
			sheet2.createRow(Readingrowindex).createCell(0).setCellValue(ah);
			sheet2.createRow(0).createCell(Readingrowindex).setCellValue(ah);

		}

		FileOutputStream fout = new FileOutputStream(src);
		workbook.write(fout);
	}
}

enter image description here

Ответы [ 2 ]

0 голосов
/ 08 декабря 2018

Хотите создать лист с одинаковыми ячейками в первом столбце и первой строке, как в именованной таблице?Если да, вам нужно изменить код, потому что вы всегда переписываете первую строку, поэтому вы получаете только последний элемент.Сделайте это:

    File src = new File("C:\\Users\\xyz\\Desktop\\folder\\file.xlsx");
    FileInputStream file = new FileInputStream(src);
    Workbook workbook = new XSSFWorkbook(file);
    Sheet sheet1 = workbook.getSheetAt(0);
    int rows = sheet1.getPhysicalNumberOfRows();
    workbook.createSheet();
    Sheet sheet2 = workbook.getSheetAt(1);
    Row sheet2FirstRow = sheet2.createRow(0);
    for (int Readingrowindex = 1; Readingrowindex < rows; Readingrowindex++) {

        String ah = sheet1.getRow(Readingrowindex).getCell(1).getStringCellValue();
        sheet2.createRow(Readingrowindex).createCell(0).setCellValue(ah);
        Cell cell = sheet2FirstRow.createCell(Readingrowindex);
        cell.setCellValue((String) ah);

    }

    FileOutputStream fout = new FileOutputStream(src);
    workbook.write(fout);
0 голосов
/ 08 декабря 2018

Я думаю, это потому, что вы продолжаете создавать строку 0 снова и снова, поэтому она перезаписывает то, что вы уже создали.

Возможно, вы захотите сделать что-то вроде этого:

if(sheet2.getRow() == null){
    sheet2.createRow(0).createCell(Readingrowindex).setCellValue(ah);
}else{
    sheet2.getRow(0).createCell(Readingrowindex).setCellValue(ah);
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...