From e4599a03ae95a9e1f70ffa0f47da694650b3c392 Mon Sep 17 00:00:00 2001 From: Yegor Kozlov Date: Sat, 23 May 2009 08:20:55 +0000 Subject: [PATCH] Fixed XSSFCell to properly read inline strings git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@777834 13f79535-47bb-0310-9956-ffa450edef68 --- src/documentation/content/xdocs/changes.xml | 1 + src/documentation/content/xdocs/status.xml | 1 + .../apache/poi/xssf/usermodel/XSSFCell.java | 18 ++++++++--- .../poi/xssf/usermodel/TestXSSFCell.java | 29 ++++++++++++++++++ .../org/apache/poi/hssf/data/xlsx-jdbc.xlsx | Bin 0 -> 3072 bytes 5 files changed, 45 insertions(+), 4 deletions(-) create mode 100755 src/testcases/org/apache/poi/hssf/data/xlsx-jdbc.xlsx diff --git a/src/documentation/content/xdocs/changes.xml b/src/documentation/content/xdocs/changes.xml index 939ab49263..b79dac6509 100644 --- a/src/documentation/content/xdocs/changes.xml +++ b/src/documentation/content/xdocs/changes.xml @@ -37,6 +37,7 @@ + 47206 - Fixed XSSFCell to properly read inline strings 47250 - Fixed FontRecord to expect unicode flags even when name length is zero 47198 - Fixed formula evaluator comparison of -0.0 and 0.0 47229 - Fixed ExternalNameRecord to handle DDE links diff --git a/src/documentation/content/xdocs/status.xml b/src/documentation/content/xdocs/status.xml index 481dce9d50..5689633510 100644 --- a/src/documentation/content/xdocs/status.xml +++ b/src/documentation/content/xdocs/status.xml @@ -34,6 +34,7 @@ + 47206 - Fixed XSSFCell to properly read inline strings 47250 - Fixed FontRecord to expect unicode flags even when name length is zero 47198 - Fixed formula evaluator comparison of -0.0 and 0.0 47229 - Fixed ExternalNameRecord to handle DDE links diff --git a/src/ooxml/java/org/apache/poi/xssf/usermodel/XSSFCell.java b/src/ooxml/java/org/apache/poi/xssf/usermodel/XSSFCell.java index 3143037430..63a3d80813 100644 --- a/src/ooxml/java/org/apache/poi/xssf/usermodel/XSSFCell.java +++ b/src/ooxml/java/org/apache/poi/xssf/usermodel/XSSFCell.java @@ -242,14 +242,24 @@ public final class XSSFCell implements Cell { rt = new XSSFRichTextString(""); break; case CELL_TYPE_STRING: - if (!cell.isSetV()) rt = new XSSFRichTextString(""); - else { - if (cell.getT() == STCellType.INLINE_STR) { - return new XSSFRichTextString(cell.getV()); + if (cell.getT() == STCellType.INLINE_STR) { + if(cell.isSetIs()) { + //string is expressed directly in the cell definition instead of implementing the shared string table. + rt = new XSSFRichTextString(cell.getIs()); + } else if (cell.isSetV()) { + //cached result of a formula + rt = new XSSFRichTextString(cell.getV()); } else { + rt = new XSSFRichTextString(""); + } + } else { + if (cell.isSetV()) { int idx = Integer.parseInt(cell.getV()); rt = new XSSFRichTextString(sharedStringSource.getEntryAt(idx)); } + else { + rt = new XSSFRichTextString(""); + } } break; case CELL_TYPE_FORMULA: diff --git a/src/ooxml/testcases/org/apache/poi/xssf/usermodel/TestXSSFCell.java b/src/ooxml/testcases/org/apache/poi/xssf/usermodel/TestXSSFCell.java index f97a6d1b81..40a937b110 100755 --- a/src/ooxml/testcases/org/apache/poi/xssf/usermodel/TestXSSFCell.java +++ b/src/ooxml/testcases/org/apache/poi/xssf/usermodel/TestXSSFCell.java @@ -19,6 +19,7 @@ package org.apache.poi.xssf.usermodel; import org.apache.poi.ss.usermodel.*; import org.apache.poi.xssf.XSSFITestDataProvider; +import org.openxmlformats.schemas.spreadsheetml.x2006.main.STCellType; /** * @author Yegor Kozlov @@ -50,4 +51,32 @@ public final class TestXSSFCell extends BaseTestCell { cell.setCellFormula(null); cell.setCellValue("456"); } + + /** + * Test that we can read inline strings that are expressed directly in the cell definition + * instead of implementing the shared string table. + * + * Some programs, for example, Microsoft Excel Driver for .xlsx insert inline string + * instead of using the shared string table. See bug 47206 + */ + public void testInlineString() throws Exception { + XSSFWorkbook wb = (XSSFWorkbook)_testDataProvider.openSampleWorkbook("xlsx-jdbc.xlsx"); + XSSFSheet sheet = wb.getSheetAt(0); + XSSFRow row = sheet.getRow(1); + + XSSFCell cell_0 = row.getCell(0); + assertEquals(STCellType.INT_INLINE_STR, cell_0.getCTCell().getT().intValue()); + assertTrue(cell_0.getCTCell().isSetIs()); + assertEquals("A Very large string in column 1 AAAAAAAAAAAAAAAAAAAAA", cell_0.getStringCellValue()); + + XSSFCell cell_1 = row.getCell(1); + assertEquals(STCellType.INT_INLINE_STR, cell_1.getCTCell().getT().intValue()); + assertTrue(cell_1.getCTCell().isSetIs()); + assertEquals("foo", cell_1.getStringCellValue()); + + XSSFCell cell_2 = row.getCell(2); + assertEquals(STCellType.INT_INLINE_STR, cell_2.getCTCell().getT().intValue()); + assertTrue(cell_2.getCTCell().isSetIs()); + assertEquals("bar", row.getCell(2).getStringCellValue()); + } } \ No newline at end of file diff --git a/src/testcases/org/apache/poi/hssf/data/xlsx-jdbc.xlsx b/src/testcases/org/apache/poi/hssf/data/xlsx-jdbc.xlsx new file mode 100755 index 0000000000000000000000000000000000000000..d9823b428e7c427c262b323127dcc66240527456 GIT binary patch literal 3072 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 JzvX5B`XBa6%C7(b literal 0 HcmV?d00001 -- 2.39.5