doudao9915 2015-02-07 15:33
浏览 45
已采纳

使用PHP导入到单个列的Excel到MySQL

I'm trying to upload an excel file into my mysql database using php, but I have two problems: the first one, i'm getting a "Notice: Undefined offset:" warning for each row of the .csv file, and the second problem, is that it's importing all the three columns of the .csv file into a single one of the db.

My code is the following:

<?php 
if(isset($_POST["Import"]))
{

    $conexion=mysql_connect("localhost","root","") or die("Problemas en la conexion");
    mysql_select_db("kontor",$conexion) or die("Problemas en la seleccion de la base de datos");

    echo $filename=$_FILES["file"]["tmp_name"];
    if($_FILES["file"]["size"] > 0)
    {
        $file = fopen($filename, "r");
        $count = 0; 
        while (($emapData = fgetcsv($file, 10000, ",")) !== FALSE)
        {
            $count++; 
            if($count>1){  
            mysql_query("INSERT into stock (nombre,prneto,descr) values ('$emapData[0]','$emapData[1]','$emapData[2]')", $conexion) 
or die("Problemas en el select".mysql_error());

            }       
        }
        fclose($file);
        echo 'Archivo importado';
        //header('Location: index.php');
    }
    else
        echo 'Formato de archivo incorrecto';
}
?>
  • 写回答

2条回答 默认 最新

  • dongxie2756 2015-02-07 16:33
    关注

    Just take a look at the csv-file ... what separator and enclosure are used?

    Excel often uses ; and " for separator and enclosure.

    most of the time one of these will do the job:

    while (($emapData = fgetcsv($file, 10000, ";", '"')) !== FALSE)
    
    // or
    
    while (($emapData = fgetcsv($file, 10000, ",", '"')) !== FALSE) 
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
  • ¥20 怎么用dlib库的算法识别小麦病虫害
  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
  • ¥15 java写代码遇到问题,求帮助
  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?