-
Notifications
You must be signed in to change notification settings - Fork 84
/
Copy pathsample.php
executable file
·95 lines (76 loc) · 2.13 KB
/
sample.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
<?php
date_default_timezone_set('UTC');
require('XLSXReader.php');
$xlsx = new XLSXReader('sample.xlsx');
$sheetNames = $xlsx->getSheetNames();
?>
<!DOCTYPE html>
<html>
<head>
<title>XLSXReader Sample</title>
<style>
body {
font-family: Helvetica, sans-serif;
font-size: 12px;
}
table, td {
border: 1px solid #000;
border-collapse: collapse;
padding: 2px 4px;
}
</style>
</head>
<body>
<h1>XLSXReader Examples</h1>
<h2>Sheet Names</h2>
<p>List of the sheets in this workbook (indexed by sheetId):</p>
<?=debug($sheetNames);?>
<hr>
<h2>All Sheets</h2>
<p>Loop through all sheets, printing the sheet name and all of the sheet data in a table</p>
<?
foreach($sheetNames as $sheetName) {
$sheet = $xlsx->getSheet($sheetName);
?>
<h3><?=escape($sheetName);?></h3>
<?
array2Table($sheet->getData());
}
?>
<hr>
<h2>Date Handling</h2>
<p>Excel dates are returned as integers and need to be converted to Unix timestamps for ease of use in PHP.
This examples takes the data in the 'Dates' sheet and modifies it to include columns for the Excel date,
the converted Unix Timestamp, the timestamp in ISO 8601 format, and the data from the second column in the sheet.</p>
<p>XLSXReader does not do automatic conversion of dates to Unix Timestamps, instead you must call the static function
<code>XLSXReader::toUnixTimeStamp</code> on an Excel date (integer) to convert it.</p>
<?
$data = array_map(function($row) {
$converted = XLSXReader::toUnixTimeStamp($row[0]);
return array($row[0], $converted, date('c', $converted), $row[1]);
}, $xlsx->getSheetData('Dates'));
array_unshift($data, array('Excel Date', 'Unix Timestamp', 'Formatted Date', 'Data'));
array2Table($data);
?>
</body>
</html>
<?
function array2Table($data) {
echo '<table>';
foreach($data as $row) {
echo "<tr>";
foreach($row as $cell) {
echo "<td>" . escape($cell) . "</td>";
}
echo "</tr>";
}
echo '</table>';
}
function debug($data) {
echo '<pre>';
print_r($data);
echo '</pre>';
}
function escape($string) {
return htmlspecialchars($string, ENT_QUOTES);
}