php - 尝试根据名称将 CSV 加载到 MySql 表中

标签 php mysql database csv

您好,我正在尝试编写一个脚本,根据名称将 csv 加载到不同的表中。

例如,Brooklyn Nets 24-01-2015.csv 或 Brooklyn Nets 28-01-2015.csv 应加载到 mysql 数据库上的 Brooklyn Nets 表,但应跳过 Boston Celtics 24-01-2015.csv。 CSV 字段与表匹配,因此无需映射。

我不知道从哪里开始。有谁指点一下吗?

最佳答案

这里有关于如何导入 CSV 的完整示例

<?php

$connect = mysql_connect('localhost','root','12345');
if (!$connect) {
die('Could not connect to MySQL: ' . mysql_error());
}

$cid =mysql_select_db('test',$connect);
// supply your database name

define('CSV_PATH','C:/wamp/www/csvfile/');
// path where your CSV file is located

$csv_file = CSV_PATH . "infotuts.csv"; // Name of your CSV file
$csvfile = fopen($csv_file, 'r');
$theData = fgets($csvfile);
$i = 0;
while (!feof($csvfile)) {
$csv_data[] = fgets($csvfile, 1024);
$csv_array = explode(",", $csv_data[$i]);
$insert_csv = array();
$insert_csv['ID'] = $csv_array[0];
$insert_csv['name'] = $csv_array[1];
$insert_csv['email'] = $csv_array[2];
$query = "INSERT INTO csvdata(ID,name,email)
VALUES('','".$insert_csv['name']."','".$insert_csv['email']."')";
$n=mysql_query($query, $connect );
$i++;
}
fclose($csvfile);

echo "File data successfully imported to database!!";
mysql_close($connect);
?>

(来源:http://www.infotuts.com/import-csv-file-data-in-mysql-php/)

关于如何从文件名获取表名,当你获取上传的文件时尝试解析名称,你将得到表:

if ($_FILES[csv][size] > 0) { 

    //get the csv file 
    $file = $_FILES[csv][tmp_name];  <-- // Parse this
   ...
}

关于php - 尝试根据名称将 CSV 加载到 MySql 表中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28142713/

相关文章:

php - {$foo|@print_r} 在屏幕上打印 '{$foo|@print_r}'

Foreach 循环中的 PHP 2 数组?

mysql按天分区

php - 面向对象的数据库连接

database - 使用 Doctrine 2 连接两个表的工作示例

php - 使用一个ajax响应更新html中的两个相同值

Php - 使用 mb_ 函数从 mysql 数据库中查找输入的前两个字符

当我删除互联网 cookies/历史记录时,php 下拉 session 被删除

java - "The method setListAdapter(ArrayAdapter) is undefined for the type create"

php - 我如何回应变量?