Как записать данные столбца для вывода excel из input excel с использованием JAVA POI - PullRequest
0 голосов
/ 25 апреля 2018

Мое требование - прочитать данные из входного файла Excel и записать их в выходной файл Excel. Я использую JAVA 8 И APACHE POI

В процессе записи я изменяю формат даты для определенного столбца с мм / дд / гггг до дд / мм / гггг

Нижеприведенный код устанавливает текущую дату в Excel, я хочу установить те же значения ввода Excel в выводе Excelно с новым определенным форматом.

Любая помощь будет очень признательна

Ниже Обновлено код:

    import java.io.File;
    import java.io.FileInputStream;
    import java.io.FileNotFoundException;
    import java.io.FileOutputStream;
    import java.io.IOException;
    import java.io.OutputStream;
    import java.util.Iterator;
    import org.apache.poi.openxml4j.exceptions.InvalidFormatException;
    import org.apache.poi.openxml4j.opc.OPCPackage;
    import org.apache.poi.ss.usermodel.Cell;
    import org.apache.poi.ss.usermodel.CellStyle;
    import org.apache.poi.ss.usermodel.CreationHelper;
    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.ss.usermodel.WorkbookFactory;
    import org.apache.poi.xssf.usermodel.XSSFCellStyle;
    import org.apache.poi.xssf.usermodel.XSSFCreationHelper;
    import org.apache.poi.xssf.usermodel.XSSFRow;
    import org.apache.poi.xssf.usermodel.XSSFSheet;
    import org.apache.poi.xssf.usermodel.XSSFWorkbook;


  class DateFormatDemo1{ 
    public static void main( String[] args ) throws IOException, InvalidFormatException, ParseException
    {
        OPCPackage pkg = OPCPackage.open(new File("C:\\DateFormatIssue\\SourceFile\\S.xlsx"));
        XSSFWorkbook wb = new XSSFWorkbook(pkg); 
        XSSFCreationHelper createHelper = wb.getCreationHelper();

        XSSFSheet sheet = wb.getSheetAt(0);      // Create spreadsheet in workbook
        Iterator<Row> iterator = sheet.iterator();
        Cell cell = null;
        Row row=null;
        row=iterator.next();
        int pos=11;
        while(iterator.hasNext())
        {
            row=iterator.next();

            cell= row.getCell(pos-1);


            XSSFCellStyle cellStyle = (XSSFCellStyle)cell.getCellStyle();
            cellStyle.setDataFormat( createHelper.createDataFormat().getFormat("M/dd/yyyy")); // set the format of the date  
            SimpleDateFormat sdf = new SimpleDateFormat("d/M/yyyy");           
            Date d=null;


            /** below if block converts dates which are in format d/M/yyyy (15/04/2017) to M/d/yyyy (4/15/2017)**/
            if (cell.getCellType() == Cell.CELL_TYPE_STRING)
            {    

                d= sdf.parse(cell.getStringCellValue());
                cell.setCellValue(d);
                cell.setCellStyle(cellStyle);       

            }


            else  if(cell.getCellType() == Cell.CELL_TYPE_NUMERIC)
            {
                cell.setCellValue(cell.getNumericCellValue()); 

            }
        }




        FileOutputStream outFile =new FileOutputStream(new File("C:\\DateFormatIssue\\OutputFile\\output.xlsx"));
        wb.write(outFile);
        wb.close();
        outFile.close();
        pkg.close();




    }}
...