根据标头将csv数据导入数据库

时间:2011-10-28 19:54:01

标签: php mysql csv import header

这是我的脚本。

     if (isset($_POST['submit'])) {
     if (is_uploaded_file($_FILES['filename']['tmp_name'])) {
        echo "<h1>" . "File ". $_FILES['filename']['name'] ." uploaded successfully." . "<br></h1>";
    echo "<h2>Displaying contents:</h2>";
    readfile($_FILES['filename']['tmp_name']);
    echo "<br>";
    echo $headers;
  }


$handle = fopen($_FILES['filename']['tmp_name'], "r");

     $header = fgetcsv($handle);

     while(! feof($handle)){

while (($data = fgetcsv($handle, 1000, ",")) !== FALSE) {
    $import="INSERT into CSVtest($header[0],$header[1],$header[2],$header[3],$header[4]) 
                     values
                     ('$data[0]','$data[1]','$data[2]','$data[3]','$data[4]')";

    mysql_query($import) or die(mysql_error());
         }

    }

fclose($handle);

echo "Done";

   }

这是我根据标题将数据插入数据库的方式,即使它与表列的排列方式不同。 如果csv只有“cell,firstname,lastname”(并且我的表只有这3列)那么它仍然可以工作......但是如果有“cell,address,company,firstname,lastname”那么它会告诉我未知的列错误。

实际上我希望有一个功能,即使csv中有很多列,表中不存在,它仍然可以选择正确的列并插入表中。 任何人都可以给我提示如何更改我的脚本吗?我知道有很多错误...显示我的低标准脚本真的很尴尬......

提前致谢。

1 个答案:

答案 0 :(得分:3)

您可能希望使用mysql_fetch_field来获取当前列,然后遍历每个标头以确保在构建查询时它存在于表中。

http://php.net/manual/en/function.mysql-fetch-field.php