I have a HTML table
and i usePHP
.. the data inside the table is came from an CSV file
.
I can already add a new data in a new row at the end of file. My problem is, what if i want to delete existing row that is in the middle of the data in the CSV file. How can i do that? By the way i don't use any database here. I just use HTML Table
and CSV file
. Below is my code in viewing CSV and adding new data.
View
<?php
$row = 1;
if (($handle = fopen("bin/pdw_table.csv", "r+")) !== FALSE) {
?>
<table class="table table-hover table-striped table-bordered" id="table-data">
<tr>
<th>Field 1</th>
<th>Field 2</th>
<th>Field 3</th>
<th></th>
<th>Field 4</th>
<th>Field 5</th>
<th></th>
<th></th>
<th>Field 6</th>
<th>Field 7</th>
<th>Field 8</th>
<th>Field 9</th>
<th>Field 10</th>
<th>Field 11</th>
<th>Field 12</th>
<th>Field 13</th>
<th></th>
<th>Field 14</th>
<th>Field 15</th>
<th>Field 16</th>
</tr>
<?php
while (($data = fgetcsv($handle, 1000, ',')) !== FALSE) {
$num = count($data);
?>
<tr <?php if($row==0){echo "style='font-weight:bold; background-color:#CCCCCC'";} else {echo "style='background-color:#DDDDDD'";} ?> style="background-color:#DDDDDD">
<?php
for ($c=0; $c < $num; $c++) {
?>
<td><?php echo $data[$c]; ?></td>
<?php
}
?>
</tr>
<?php
$row++;
}
fclose($handle);
?>
<form method="post" name="add1" id="add1" action="<?php echo base_url();?>index.php/datacast_ctr/write_csv" autocomplete="off">
<tr class="td1" id="td1" >
<td><input type="text" name="val1" id="val1"/></td>
<td><input type="text" name="val2" id="val2"/></td>
<td><input type="text" name="val3" id="val3"/></td>
<td></td>
<td><input type="text" name="val4" id="val4"/></td>
<td><input type="text" name="val5" id="val5"/></td>
<td></td>
<td></td>
<td><input type="text" name="val6" id="val6"/></td>
<td><input type="text" name="val7" id="val7"/></td>
<td><input type="text" name="val8" id="val8"/></td>
<td><input type="text" name="val9" id="val9"/></td>
<td><input type="text" name="val10" id="val10"/></td>
<td><input type="text" name="val11" id="val11"/></td>
<td><input type="text" name="val12" id="val12"/></td>
<td><input type="text" name="val13" id="val13"/></td>
<td></td>
<td><input type="text" name="val14" id="val14"/></td>
<td><input type="text" name="val15" id="val15"/> </td>
<td><input type="text" name="val16" id="val16"/></td>
</tr>
</form>
</table>
<?php
}
?>
CONTROLLER (code for adding new data EOF)
function write_csv()
{
$R1 = $this->input->post('val1');
$R2 = $this->input->post('val2');
$R3 = $this->input->post('val3');
$H1 = $this->input->post('valh1');
$R4 = $this->input->post('val4');
$R5 = $this->input->post('val5');
$H2 = $this->input->post('valh2');
$H3= $this->input->post('valh3');
$R6 = $this->input->post('val6');
$R7 = $this->input->post('val7');
$R8 = $this->input->post('val8');
$R9 = $this->input->post('val9');
$R10 = $this->input->post('val10');
$R11 = $this->input->post('val11');
$R12 = $this->input->post('val12');
$R13 = $this->input->post('val13');
$H4 = $this->input->post('valh4');
$R14 = $this->input->post('val14');
$R15 = $this->input->post('val15');
$R16 = $this->input->post('val16');
$H5 = $this->input->post('valh5');
$data = $R1.",".$R2.",".$R3.",".$H1.",".$R4.",".$R5.",".$H2.",".$H3.",".$R6.",".$R7.",".$R8.",".$R9.",".$R10.",".$R11.",".$R12.",".$R13.",".$H4.",".$R14.",".$R15.",".$R16;
$list = array($data);
$file = fopen("./bin/pdw_table.csv","a+");
foreach ($list as $line)
{
fputcsv($file,explode(',',$line));
}
fclose($file);
redirect('datacast_ctr');
}