要做在線Excel表格編輯功能,Excel的xls文件格式的解析就是個問題,畢竟這是微軟Office的私有專利格式.
所以要做的話還是用通用的csv(Comma Separated Value,逗號分隔值)格式吧.
各種辦公軟件都能識別csv表格,其實就是以特定分隔符(比如逗號)分隔單元格的表格.
拿PHP來說,fgetcsv讀入csv表格,返回一個數組,
然後foreach輸出成HTML的<table>,這步操作幾行代碼就能實現,非常簡單.
工作量主要還在於浏覽器前端,建議你用jQuery進行DOM和AJAX操作,
要實現phpMyAdmin那樣細粒度雙擊單元格編輯,然後AJAX提交也不難,
或者整個表格寫好後一次性$("form").serialize();然後AJAX提交也可以.
CSV表格的幾條規則:
1.每一行的單元格內容之間用逗號分隔.
2.如果單元格的內容本身有逗號,這個單元格的內容將會用引號包含.
3.如果單元格的內容本身有引號:
(1)引號不在首或尾,這個單元格內容不會被引號包含.
(2)引號在首或尾,這個單元格內容會被引號包含,並且原來首尾的引號會被轉義.
讀寫CSV
<?php
header('Content-Type: text/plain; charset=utf-8');
//導出CSV表格:數組轉CSV
$arr = array (
array('ab', 'cd'),
array('"a,b"', '"c,d"'),
);
$fp = fopen('file.csv', 'w');
foreach ($arr as $row) {
//將一行格式化為CSV並寫入文件指針
fputcsv($fp, $row);
}
fclose($fp);
unset($arr);
//導入CSV表格:CSV轉數組
$fp = fopen('file.csv', 'r');
while ( ($row = fgetcsv($fp)) !== FALSE ) {
//從文件指針中讀入一行並解析CSV
$arr[] = $row;
}
fclose($fp);
var_export($arr);
另存為一個獨立文件
download.php:
<?php $list = array ( 'aaa,bbb,ccc,dddd', '123,456,789', '"aaa","bbb"' ); session_start(); $_SESSION['outputArray']=$list; ?> <a href="test.php" target="_blank">下載csv文件</a>
<?php
session_start();
$outputArray=$_SESSION['outputArray'];
header('Content-Type: application/csv');
header('Content-Disposition: attachment;filename="sales.csv"');
$output=fopen('php://output','w') or die("can not open");
foreach ($outputArray as $line) {
fputcsv($output, split(',', $line));
}
fclose($output) or die("can not close");
?>
<?php
$list = array (
'aaa,bbb,ccc,dddd',
'123,456,789',
'"aaa","bbb"'
);
$fp = fopen('file.csv', 'w');
foreach ($list as $line) {
fputcsv($fp, split(',', $line));
}
fclose($fp);
?>