0

PHPExcelを使用してExcel(xlsx)ファイルをHTMLページにロードしています。

以下のフォームを使用して新しいフォームを追加することができますが、残念ながら、追加するすべての行が最初の行を上書きします。以前の付加価値を上書きしないように更新する方法はありますか?

新しい行を追加するためのフォームは次のとおりです。

<form action="" method="post" id="AddForm" name="AddForm">
<input type="text" id="company" name="company" value="Enter new name" />
<input type="submit" id="save" name="add" value="add"/>
</form>

以下は、新しい行をロード/表示/追加するために使用するコードです

    <?php

    require_once '../inc/phpexcel/Classes/PHPExcel.php';
    require_once '../inc/phpexcel/Classes/PHPExcel/IOFactory.php';
    $objPHPExcel = PHPExcel_IOFactory::load("myExcelFile.xlsx");
    $objWorksheet = $objPHPExcel->getActiveSheet();

    //add the new row
    $num_rows = $objPHPExcel->getActiveSheet()->getHighestRow();
    $objWorksheet->insertNewRowBefore($num_rows + 1, 1);
    $name = isset($_POST['name']) ? $_POST['name'] : '';
    if($submit){
//SAVING THE NEW ROW - on the last position in the table
    $objWorksheet->setCellValueByColumnAndRow(0,$num_rows+1,$name);
    }

    //display the table
    echo '<table>'."\n";
    echo '<thead>
    <tr>
        <th>Company Name</th>
    </tr>
    </thead>'."\n";
    echo '<tbody>'."\n";
    foreach ($objWorksheet->getRowIterator() as $row) {
    echo '<tr>'."\n";
    $cellIterator = $row->getCellIterator();
    $cellIterator->setIterateOnlyExistingCells(false);
    foreach ($cellIterator as $cell) {
    echo '<td>'.$cell->getValue().'</td>'."\n";
    }
    echo '</tr>'."\n";
    }
    echo '</tbody>'."\n";
    echo '</table>'."\n";
    ?>
4

1 に答える 1

0

私は解決策を見つけました:ループ内では、各リクエストの後にファイルを保存する必要があります:

$objWorksheet->setCellValueByColumnAndRow(0,$num_rows+1,$company_name);
$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007');
$objWriter->save('myExcelFile.xlsx');
echo date('H:i:s') . " Write to Excel2007 format\n";
于 2012-09-14T13:55:31.997 に答える