如何使用php将包含合并单元格的.csv文件导出到mysql中?

时间:2015-03-10 06:09:48

标签: php mysql csv

在我的.csv文件中有一个这样的数据: id |代码|名称 1mca | 3ca1523 | C      | 3ca1524 | CPP      | 3ca1525 | java的 3mca | 3ca1621 | PHP      | 3ca1624 | OOAD

我的代码将其导出到mysql:

<?php
$db = mysqli_connect("localhost", "root", "") or die("could not connect");

if(!$db)

die("no db");

if(!mysqli_select_db($db,"phptester"))

die("No database selected.");

if(isset($_POST['submit']))
{
$uploaddir = 'uploads/';
$uploadfile = $uploaddir . basename($_FILES["file"]["name"]);
echo $uploadfile;


if (move_uploaded_file($_FILES["file"]["tmp_name"], $uploadfile)) 
{

$handle = fopen("$uploadfile", "r");
while (($data = fgetcsv($handle, 1000, ",")) !== FALSE)
{

$import="INSERT into subject(sem,code,name) values('$data[0]','$data[1]','$data[2]')";
mysqli_query($db,$import) or die(mysql_error());
}
fclose($handle);
print "Import done";
}
}
else
{
print "<form action='index.php' method='post' enctype='multipart/form-data'>";
print "Choose file to import:<br><br>";
print "<input type='file' name='file' id='file'><br><br>";
print "<input type='submit' name='submit' value='extract'></form>";
}
?>

所以,csv文件中有一个合并列,当我运行这个脚本时,第一条记录像这样插入1mca,3ca1524,c和下一条记录,就像这样,3ca1525,cpp而不是我想在第二条记录中应该有在第一个字段中插入1mca如何实现这个?

1 个答案:

答案 0 :(得分:0)

在线的位置是: while (($data = fgetcsv($handle, 1000, ",")) !== FALSE) 尝试替换为: while (($data = fgetcsv($handle, 1000, "|")) !== FALSE)

fgetcsv 的第三个参数是从csv获取数据的分隔符。你有“”而不是“ |