Um die Online-Excel-Tabellenbearbeitungsfunktion zu nutzen, ist das Parsen des Excel-Dateiformats ein Problem. Schließlich handelt es sich hierbei um ein privates Patentformat von Microsoft Office.
Wenn Sie es also tun möchten, sollten Sie es verwenden das universelle CSV-Format (Comma Separated Value, durch Kommas getrennte Werte)
Verschiedene Office-Software kann CSV-Tabellen erkennen, bei denen es sich tatsächlich um Tabellen mit durch bestimmte Trennzeichen (wie Kommas) getrennten Zellen handelt.
Nehmen Sie PHP als Beispiel. fgetcsv liest die CSV-Tabelle und gibt ein Array zurück,
und gibt es dann als HTML
Es ist nicht schwierig, eine feinkörnige Doppelklick-Zellenbearbeitung wie phpMyAdmin zu erreichen und sie dann über AJAX zu senden > Oder Sie können das gesamte Formular auf einmal schreiben und $("form").serialize(); und dann über AJAX senden.
Einige Regeln für CSV-Tabellen:
2. Wenn der Inhalt der Zelle selbst ein Komma hat, wird der Inhalt dieser Zelle in Anführungszeichen gesetzt
3 enthält Anführungszeichen:
(1) Das Anführungszeichen steht nicht am Anfang oder am Ende, der Zelleninhalt wird nicht in Anführungszeichen gesetzt.
(2) Das Anführungszeichen steht am Anfang oder am Ende des Inhalts Diese Zelle wird in Anführungszeichen gesetzt und das ursprüngliche erste und letzte Anführungszeichen wird maskiert.
CSV lesen und schreiben
<?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);
<?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); ?>