dsgixl5195 2018-06-20 05:17
浏览 61

在制作PHPExcel Reader时不能使用标量作为数组

$file = 'upload/'.$filename;

    //read file from path
    $objPHPExcel = PHPExcel_IOFactory::createReader('Excel2007');
    $objPHPExcel->setReadDataOnly(true);
    $objPHPExcel = $objPHPExcel->load($file);
    $objWorksheet = $objPHPExcel->getActiveSheet();

    $highestRow = $objWorksheet->getHighestRow();
    $highestColumn = $objWorksheet->getHighestColumn();
    $highestColumnIndex = PHPExcel_Cell::columnIndexFromString($highestColumn);

    //$row = array();

    for($row=1; $row <= $highestRow; ++$row){
        for($col=0; $col <= $highestColumnIndex; ++$col){
        $row[$col] = $objWorksheet->getCellByColumnAndRow($col,$row)->getValue();
    }
    }
        echo "<pre>";print_r($row[$col]);echo "</pre>";

Here what is wrong with this $row. it tells me that the value type of $row is scalar. I am using array to put any cell from excel into my html.

I need to put this data into my mysql database. I'am using a Excel sheet, the sample sheet is :

(nama_lengkap, tempat_lahir, provinsi_lahir) ---> as header (Anak pertama, Jakarta, DKI) (Anak kedua, Bandung, Jawa Barat) (Anak ketiga, Semarang, Jawa Tengah)

Imagine table data:

| id | nama        | tempat_lahir | provinsi_lahir |

|----|-------------|--------|-------|

| 1  | John | Semarang  | Jawa tengah    |

| 2  | Meresa | Bandung | Jawa Barat    |

| 3  | Mike  | Jakarta   | Dki    |
  • 写回答

1条回答 默认 最新

  • douliaopan1419 2018-06-20 05:26
    关注

    Another everything is fine. But you are overwriting value in $row again and again within for loop. Here is the code should look like:

    $file = 'upload/' . $filename;
    //read file from path
    $objPHPExcel = PHPExcel_IOFactory::createReader('Excel2007');
    $objPHPExcel->setReadDataOnly(true);
    $objPHPExcel = $objPHPExcel->load($file);
    $objWorksheet = $objPHPExcel->getActiveSheet();
    
    $highestRow = $objWorksheet->getHighestRow();
    $highestColumn = $objWorksheet->getHighestColumn();
    $highestColumnIndex = PHPExcel_Cell::columnIndexFromString($highestColumn);
    
    $excelData = array();
    
    for ($row = 1; $row <= $highestRow; ++$row) {
        for ($col = 0; $col <= $highestColumnIndex; ++$col) {
            $excelData[$row][$col] = $objWorksheet->getCellByColumnAndRow($col, $row)->getValue();
        }
    }
    echo "<pre>";
    print_r($excelData);
    echo "</pre>";
    

    Take an array $excelData and store data from excel sheet in it.

    评论

报告相同问题?

悬赏问题

  • ¥15 R语言Rstudio突然无法启动
  • ¥15 关于#matlab#的问题:提取2个图像的变量作为另外一个图像像元的移动量,计算新的位置创建新的图像并提取第二个图像的变量到新的图像
  • ¥15 改算法,照着压缩包里边,参考其他代码封装的格式 写到main函数里
  • ¥15 用windows做服务的同志有吗
  • ¥60 求一个简单的网页(标签-安全|关键词-上传)
  • ¥35 lstm时间序列共享单车预测,loss值优化,参数优化算法
  • ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。
  • ¥100 为什么这个恒流源电路不能恒流?
  • ¥15 有偿求跨组件数据流路径图
  • ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值