0

我的 PHP 代码遇到了一些问题。基本上我有一个 CSV 中的人员列表,我正在使用 fgetcsv 将该文件读入表中。我想要做的是让他们的名字显示为一个链接,他们点击链接,它调用 fputcsv,并在他们的名字旁边放一个 1。

目前我只有显示部分工作。我不确定从哪里开始写作部分。

任何见解将不胜感激。

非常感谢!

  <?php
  $row = 1;
  $handle = fopen("test/list.csv", "r");
  echo("<table>");
  while (($data = fgetcsv($handle, 1000, ",")) !== FALSE) {
      echo("<tr>\r\n");
      foreach ($data as $index=>$val) {
              echo("\t<td><a href=\"#\">$val</a></td>\r\n");
      }
      echo("</tr>\r\n");
  }
  echo("</table>");
  fclose($handle);
  ?>
4

1 回答 1

2

您不能直接将 csv 文件视为数据库。您需要有一些方法来指示单击的行来自原始 csv 文件中的哪一行。通过行号,或(最好)每行中的某个唯一 ID 字段。

我会假装 csv 文件的第 0 列是该行的唯一标识符,因此您可以将其用于输出:

  foreach ($data as $index=>$val) {
          echo("\t<td><a href=\"update.php?id={$data[0]}\">$val</a></td>\r\n");
  }

然后在 update.php 脚本中,使用基本的伪代码:

<?php
$id = $GET['id'];

$fh = fopen('test/list.csv', 'rb');
$out = fopen('newlist.csv', 'wb');
while($row = fgetcsv($fh)) {
   if ($row[0] == $id) {
       $row[xxx] = 1; // write '1' for this row because it's the row that was clicked on
   }
   fputcsv($out, $row); // write out to new file
}

请注意,我正在为修改后的输出使用第二个文件。这比尝试就地编辑原始 csv 更安全。一旦您进行了任何必要的更改,您只需将新文件移到旧文件上,您的编辑就完成了。

于 2011-12-22T19:56:58.313 回答