1

我构建了这个脚本来上传 .csv 文件并将它们直接发送到我的数据库。但它不会在我的表中写入任何内容。如果我将文件上传到我的服务器并写入“file.csv”而不是“$file”,它会完美运行。但我想通过表单上传它们。谁能帮我?

形式:

<html> 
<head> 
</head> 
<body> 

<h2> CSV Import </h2> 
<form>
 <form method="post" action="imp.php" enctype="multipart/form-data"> 
  <input type="file" name="file" /> 
  <br /> 
  <input type="submit" name="submit" value="Submit" /> 
</form>
</body> 
</html>

小鬼.php:

<?php
$delimiter = ',';

$db = new mysqli('host', 'user', 'pw', 'db');


$file= $_FILES[file][temp_name];


if (($handle = fopen($file, 'r')) !== FALSE) {
    while (($data = fgetcsv($handle, 1000, $delimiter)) !== FALSE) {
        foreach($data as $i => $content) {
            $data[$i] = $db->real_escape_string($content);
        }
        $db->query("INSERT INTO table VALUES('" . implode("','", $data) . "');");
    }
    fclose($handle);
}


?>
4

2 回答 2

0

我强烈建议您使用LOAD DATA INFILE语法,因为您的服务器上有一个结构良好的 CSV 文件。

就像是:

LOAD DATA LOCAL INFILE '/path/to/local/file'
INTO TABLE table
FIELDS TERMINATED BY ',' ENCLOSED BY '"'
LINES TERMINATED BY '\r\n'

这将允许您通过单个查询上传所有内容。另请注意,如果您的 MySQL 服务器和应用程序服务器在同一台机器上,您可以省略该LOCAL选项,因为 MySQL 可以直接从指定路径的文件系统读取文件(假设它具有权限)。

这消除了打开文件并遍历它的需要。

如果您不想走这条路线,我至少建议进行批量插入并一次添加多行(而不是对每一行进行一个插入查询)。

于 2013-11-08T21:45:23.463 回答
0

它是$_FILES['file']['tmp_name']

http://www.php.net/manual/en/features.file-upload.post-method.php

即不是temp_name

于 2013-11-08T22:06:03.233 回答