JXL数字格式和单元格类型

时间:2011-06-30 14:31:20

标签: java excel jxl

我正在使用JXL编写Excel文件。客户希望某列显示带小数点后一位的数字。他们还希望单元格类型为“数字”。当我使用以下(测试)代码时,数字显示正确,但单元格类型为“自定义”。

File excelFile = new File("C:\\Users\\Rachel\\Desktop\\TestFile.xls");

WritableWorkbook excelBook = Workbook.createWorkbook(excelFile);
WritableSheet excelSheet = excelBook.createSheet("Test Sheet", 0);

WritableFont numberFont = new WritableFont(WritableFont.ARIAL);
WritableCellFormat numberFormat = new WritableCellFormat(numberFont, new NumberFormat("#0.0"));

Number numberCell = new Number(0, 0, 25, numberFormat);
excelSheet.addCell(numberCell);

excelBook.write();
excelBook.close();

如果我将数字格式更改为NumberFormats中的变量之一(例如NumberFormats.INTEGER),则单元格类型是正确的。但数字当然显示为整数。我在NumberFormats中找不到符合我需要的变量。

任何人都知道如何同时显示数字和细胞类型?我需要显示1位小数的所有数字(即使它们是整数)。我无法切换到任何其他技术,我必须使用JXL。

1 个答案:

答案 0 :(得分:10)

如果这不是你想要的,我很抱歉。但是,我对你的需求的理解是让细胞类型=数字,小数点后1位。您可以定义自己的数字格式。你可以使用这种格式(“#。0”)来得到你想要的东西(例如:900.0,23.0,34324.0和.etc)

NumberFormat decimalNo = new NumberFormat("#.0"); 
WritableCellFormat numberFormat = new WritableCellFormat(decimalNo);
//write to datasheet
Number numberCell = new Number(0, 0, 25, numberFormat); 
excelSheet.addCell(numberCell);