php - 将 CSV 文件上传到 Web 服务器并将行插入数据库

标签 php mysql file-upload

目前,我可以从名为“data.csv”的 CSV 文件中获取数据,该文件是我手动上传到网络服务器的。然后我可以将数据上传到数据库,一切正常。

我需要做的是:

  1. 只需将文件上传到网络服务器的根目录
  2. 例如,无论 CSV 文件 header 的顺序如何,即使一个用户上传的 CSV 文件中的列顺序如下(姓名 | 电子邮件 | 地址),但另一个用户上传的 CSV 文件中的列顺序如下:列的顺序如下(电子邮件|地址|姓名)。所以本质上我需要将适当的数据上传到正确的数据库字段,其中 CSV header 的名称与表中的字段名称相匹配?

代码如下:

上传.php

<?php

include('config.php');

$file = "data.csv";
$separator = ",";
$length = 0; 
$fields = array('title', 'firstName', 'secondName', 'emailAddress', 'houseNumber', 'mobileNumber', 'address1', 'address2', 'address3', 'address4', 'postcode'); 

$handle = fopen($file, "r");

$header = array_flip(fgetcsv($handle, $length, $separator));

$values = array();

$i = 1;

while(($csvData = fgetcsv($handle, $length, $separator)) !== false){

$values = array();

echo $i." - You have inserted another row of data into the database.<br>";

    foreach ($fields as $field){
        $values[] = $csvData[$header[$field]];
    }

    mysql_query("INSERT INTO csv (" . implode(',', array_keys($header)) . ") VALUES ('" . implode("','", $values) . "')"); 

$i++;

}

fclose($handle);

?>

如果我没有完全正确地解释这一点,请询问。

提前致谢。

最佳答案

以下内容应该是适合您的完整解决方案。

在你的html中

<form enctype="multipart/form-data" action="sompepage.php" method="POST">
<!-- MAX_FILE_SIZE must precede the file input field -->
<input type="hidden" name="MAX_FILE_SIZE" value="30000" />
<!-- Name of input element determines name in $_FILES array -->
Send this file: <input name="userfile" type="file" />
<input type="submit" value="Send File" />
</form>

在 PHP 中(somepage.php)

<?php
include('config.php');
$file = $_FILES['userfile']['tmp_name'];
$separator = ",";
$length = 0; 
$fields = array('title', 'firstName', 'secondName', 'emailAddress', 'houseNumber', 'mobileNumber', 'address1', 'address2', 'address3', 'address4', 'postcode'); 

$handle = fopen($file, "r");

$header = array_flip(fgetcsv($handle, $length, $separator));

$values = array();

$i = 1;

while(($csvData = fgetcsv($handle, $length, $separator)) !== false){

$values = array();

echo $i." - You have inserted another row of data into the database.<br>";

    foreach ($fields as $field){
        $values[] = $csvData[$header[$field]];
    }
    $values = array_map("mysql_real_escape_string", $values);
    mysql_query("INSERT INTO csv (" . implode(',', $fields) . ") VALUES ('" . implode("','", $values) . "')"); 

$i++;

}

fclose($handle);

?>

关于php - 将 CSV 文件上传到 Web 服务器并将行插入数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17556100/

相关文章:

python - 如果 SQLAlchemy 不存在对象,则插入对象的最快方法

javascript - 从输入字段中抓取图像以获取图像数据/显示图像

file-upload - 使用 Rails 4、强参数和 Carrierwave 上传文件

php - 在windows xp上添加mySQL包括管理工具

php - 为什么我不能从数据库中调用随机数?

php - 如何检查文件系统的权限?

mysql - TYPO3:我可以从同一服务器上的另一个数据库中提取数据吗?

javascript - Angular 未定义的多个文件上传

php - 从中间件的终止方法中的请求调用方法

php - 如何使用 codeigniter 3 调用 hooks 文件夹中的库?