使用php将csv文件导入数据库

时间:2016-11-22 18:43:56

标签: php mysql csv mysqli import

我正在尝试将csv文件导入数据库而不定义任何行,因为它会在页面加载时自动生成 -

$file = '../csv/file.csv';
$table = 'table_name';

// get structure from csv and insert db
ini_set('auto_detect_line_endings',TRUE);
$handle = fopen($file,'r');
// first row, structure
if ( ($data = fgetcsv($handle) ) === FALSE ) {
    echo "Cannot read from csv $file";die();
}
$fields = array();
$field_count = 0;
for($i=0;$i<count($data); $i++) {
    $f = strtolower(trim($data[$i]));
    if ($f) {
        // normalize the field name, strip to 20 chars if too long
        $f = substr(preg_replace ('/[^0-9a-z]/', '_', $f), 0, 255);
        $field_count++;
        $fields[] = $f.' VARCHAR(255)';
    }
}

$sql = "CREATE TABLE $table (" . implode(', ', $fields) . ')';

$conn->query($sql);
while ( ($data = fgetcsv($handle) ) !== FALSE ) {
    $fields = array();
    for($i=0;$i<$field_count; $i++) {
        $fields[] = '\''.addslashes($data[$i]).'\'';
    }
   $sql = "Insert into $table values(" . implode(', ', $fields) . ')';

   $conn->query($sql);

}
fclose($handle);
ini_set('auto_detect_line_endings',FALSE);

如果我回显它,它会加载页面中的数据并正确创建表格,只是没有将数据加载到表格中,我无法找到原因..

谢谢!

已更新

这是我回应$ sql时的第一行 -

Insert into 1001_inventory values('New', '581613', '88888888888888888', '2016', 'Toyota')

1 个答案:

答案 0 :(得分:1)

所以我发现varchar(255)对于某些字段来说很小,所以我扩展了它并解决了问题,感谢所有的帮助!