在我的.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如何实现这个?
答案 0 :(得分:0)
在线的位置是:
while (($data = fgetcsv($handle, 1000, ",")) !== FALSE)
尝试替换为:
while (($data = fgetcsv($handle, 1000, "|")) !== FALSE)
fgetcsv 的第三个参数是从csv获取数据的分隔符。你有“,”而不是“ | ”