Skip to content

Commit f6f7b47

Browse files
authored
Merge branch 'master' into Samples-Table-Column-Formula-with-Total
2 parents 0613cbd + e5697fb commit f6f7b47

File tree

4 files changed

+64
-1
lines changed

4 files changed

+64
-1
lines changed

src/PhpSpreadsheet/Reader/Xlsx.php

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -945,6 +945,10 @@ protected function loadSpreadsheetFromFile(string $filename): Spreadsheet
945945
// no style index means 0, it seems
946946
$cell->setXfIndex(isset($styles[(int) ($cAttr['s'])]) ?
947947
(int) ($cAttr['s']) : 0);
948+
// issue 3495
949+
if ($cell->getDataType() === DataType::TYPE_FORMULA) {
950+
$cell->getStyle()->setQuotePrefix(false);
951+
}
948952
}
949953
}
950954
++$rowIndex;

tests/PhpSpreadsheetTests/Reader/Xlsx/Issue3464Test.php

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -18,7 +18,8 @@ public function testReadFontColor(): void
1818
$objReader = IOFactory::createReader($inputFileType);
1919
$objReader->setReadEmptyCells(false);
2020

21-
$sheet = $objReader->load(self::$testbook)->getActiveSheet();
21+
$spreadsheet = $objReader->load(self::$testbook);
22+
$sheet = $spreadsheet->getActiveSheet();
2223
$rickText = $sheet->getCell([1, 1])->getValue();
2324
self::assertInstanceOf(RichText::class, $rickText);
2425

@@ -34,5 +35,6 @@ public function testReadFontColor(): void
3435
$font = $elements[1]->getFont();
3536
self::assertNotNull($font);
3637
self::assertEquals('ff2600', $font->getColor()->getRGB());
38+
$spreadsheet->disconnectWorksheets();
3739
}
3840
}
Lines changed: 57 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,57 @@
1+
<?php
2+
3+
namespace PhpOffice\PhpSpreadsheetTests\Reader\Xlsx;
4+
5+
use PhpOffice\PhpSpreadsheet\Reader\Xlsx;
6+
7+
class Issue3495Test extends \PHPUnit\Framework\TestCase
8+
{
9+
/**
10+
* @var string
11+
*/
12+
private static $testbook = 'tests/data/Reader/XLSX/issue.3495d.xlsx';
13+
14+
public function testPreliminaries(): void
15+
{
16+
$file = 'zip://';
17+
$file .= self::$testbook;
18+
$file2 = $file;
19+
$file .= '#xl/styles.xml';
20+
$file2 .= '#xl/worksheets/sheet1.xml';
21+
$data = file_get_contents($file);
22+
if ($data === false) {
23+
self::fail('Unable to read file');
24+
} else {
25+
// default style plus one other style
26+
self::assertStringContainsString(
27+
'<cellXfs count="2">'
28+
. '<xf numFmtId="0" fontId="0" fillId="0" borderId="0" xfId="0"/>'
29+
. '<xf numFmtId="0" fontId="0" fillId="0" borderId="0" xfId="0" quotePrefix="1"/>',
30+
$data
31+
);
32+
}
33+
$data = file_get_contents($file2);
34+
if ($data === false) {
35+
self::fail('Unable to read file');
36+
} else {
37+
// cells B1, C1, D1 all nominally use quotePrefix s="1"
38+
self::assertStringContainsString('<c r="B1" s="1">', $data);
39+
self::assertStringContainsString('<c r="C1" s="1" t="s">', $data);
40+
self::assertStringContainsString('<c r="D1" s="1" t="s">', $data);
41+
}
42+
}
43+
44+
public function testFormulaDespiteQuotePrefix(): void
45+
{
46+
$reader = new Xlsx();
47+
$spreadsheet = $reader->load(self::$testbook);
48+
$sheet = $spreadsheet->getActiveSheet();
49+
self::assertSame('=2+3', $sheet->getCell('B1')->getValue());
50+
self::assertSame('=1+2', $sheet->getCell('C1')->getValue());
51+
self::assertSame('3', $sheet->getCell('D1')->getValue());
52+
self::assertSame(5, $sheet->getCell('B1')->getCalculatedValue());
53+
self::assertSame('=1+2', $sheet->getCell('C1')->getCalculatedValue());
54+
self::assertSame('3', $sheet->getCell('D1')->getCalculatedValue());
55+
$spreadsheet->disconnectWorksheets();
56+
}
57+
}
10.7 KB
Binary file not shown.

0 commit comments

Comments
 (0)