本文实例讲述了ThinkPHP 框架实现的读取excel导入数据库操作。分享给大家供大家参考,具体如下:
入口文件中:
1
2
|
require_once VENDOR_PATH. 'PHPExcel/PHPExcel/IOFactory.php' ; require_once VENDOR_PATH. 'PHPExcel/PHPExcel.php' ; |
PHP:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
|
namespace Home\Controller; class ExcelController extends CommonController { public function Import() { // vendor('PHPExcel.PHPExcel.IOFactory'); vendor( "PHPExcel.PHPExcel.PHPExcel" ); vendor( "PHPExcel.PHPExcel.Writer.Excel5" ); vendor( "PHPExcel.PHPExcel.Writer.Excel2007" ); //$excel = new PHPExcel(); $fileName = './trans_rate.xlsx' ; date_default_timezone_set( 'PRC' ); // 读取excel文件 try { $objPHPExcel = \PHPExcel_IOFactory::load( $fileName ); $inputFileType = \PHPExcel_IOFactory::identify( $fileName ); $objReader = \PHPExcel_IOFactory::createReader( $inputFileType ); // $objPHPExcel = $objReader->load($fileName); // 确定要读取的sheet $sheet = $objPHPExcel->getSheet(0); $highestRow = $sheet ->getHighestRow(); $highestColumn = $sheet ->getHighestColumn(); // 获取一行的数据 // $phone_str = ''; for ( $row = 3; $row <= $highestRow ; $row ++) { $row_data = $sheet ->rangeToArray( 'A' . $row . ':' . $highestColumn . $row , NULL, TRUE, FALSE); //获取excel表中一行的数组数据 //dump($row_data); $row_data = $row_data [0]; $time = date ( 'Y-m-d H:i:s' , strtotime (trim( $row_data [0]))); $start_province = trim( $row_data [1]); $start_city = trim( $row_data [2]); ... // $phone_str .= '"' . $phone . '",'; $where [ 'phone' ] = $phone ; $id_arr = M(数据表名)->where( $where )->getField( 'id' ); $user_id = ! empty ( $id_arr ) ? $id_arr : 0; $fields [] = [ '数据表字段' => $user_id , //用户id ... ]; } // dump($fields); $rate_add = M(数据表名)->addAll( $fields ); dump( $rate_add ); echo M()->getLastSql(); if (!(0 < $rate_add )) { CommonController::logProfile( '添加excel数据,SQL:' . M()->getLastSql()); $this ->endBack(0); } // echo $phone_str . '<br />'; // dump($user_id); } catch (Exception $e ) { die ( '加载文件发生错误:"' . pathinfo ( $fileName , PATHINFO_BASENAME) . '": ' . $e ->getMessage()); } }} |
php读取excel表数据:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
<?php include 'ThinkPHP/Library/Vendor/PHPExcel/PHPExcel/IOFactory.php' ; $inputFileName = './trans_rate.xlsx' ; date_default_timezone_set( 'PRC' ); // 读取excel文件 try { $inputFileType = PHPExcel_IOFactory::identify( $inputFileName ); $objReader = PHPExcel_IOFactory::createReader( $inputFileType ); $objPHPExcel = $objReader ->load( $inputFileName ); } catch (Exception $e ) { die ( '加载文件发生错误:"' . pathinfo ( $inputFileName ,PATHINFO_BASENAME). '": ' . $e ->getMessage()); } // 确定要读取的sheet $sheet = $objPHPExcel ->getSheet(0); $highestRow = $sheet ->getHighestRow(); $highestColumn = $sheet ->getHighestColumn(); // 获取一行的数据 for ( $row = 1; $row <= $highestRow ; $row ++){ // Read a row of data into an array $rowData = $sheet ->rangeToArray( 'A' . $row . ':' . $highestColumn . $row , NULL, TRUE, FALSE); //这里得到的rowData都是一行的数据,得到数据后自行处理 var_dump( $rowData ); echo "<br>" ; } //$data为从excel中获取到的数组 for ( $i =0; $i < count ( $data ); $i ++){ echo '<br>' ; $gettime = explode ( '-' , $data [ $i ][0]); if ( checkdate ( $month = $gettime [0], $day = $gettime [1], $year = $gettime [2])){ echo gmdate ( 'Y-m-d' , gmmktime (0,0,0, $month , $day , $year )); } else { echo ( $data [ $i ][0]); } echo '-----------' ; echo $data [ $i ][1]; } |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
|
<?php include 'ThinkPHP/Library/Vendor/PHPExcel/PHPExcel/IOFactory.php' ; $inputFileName = './test.xlsx' ; date_default_timezone_set( 'Asia/Shanghai' ); // 读取excel文件 try { $inputFileType = PHPExcel_IOFactory::identify( $inputFileName ); $objReader = PHPExcel_IOFactory::createReader( $inputFileType ); $objPHPExcel = $objReader ->load( $inputFileName ); // 确定要读取的sheet,什么是sheet,看excel的右下角,真的不懂去百度吧 $sheet = $objPHPExcel ->getSheet(0); $highestRow = $sheet ->getHighestRow(); //最大行 $highestColumn = $sheet ->getHighestColumn(); //最大列 $data = array (); for ( $rowIndex =2; $rowIndex <= $highestRow ; $rowIndex ++){ //循环读取每个单元格的内容。注意行从1开始,列从A开始 for ( $colIndex = 'A' ; $colIndex <= $highestColumn ; $colIndex ++){ $addr = $colIndex . $rowIndex ; if ( $colIndex === "A" ){ //指定H列为时间所在列 $cell = gmdate ( "Y-m-d H:i:s" , PHPExcel_Shared_Date::ExcelToPHP( $sheet ->getCell( $addr )->getValue())); // $cell = PHPExcel_Shared_Date::ExcelToPHP($sheet->getCell($addr)->getValue()); // var_dump($cell);die; } else { $cell = $sheet ->getCell( $addr )->getValue(); } // if($cell instanceof PHPExcel_RichText){ //富文本转换字符串 // $cell = $cell->__toString(); // } $data [ $rowIndex ][ $colIndex ] = $cell ; } } // return $data; var_dump( $data ); } catch (Exception $e ) { die ( '加载文件发生错误:"' . pathinfo ( $inputFileName ,PATHINFO_BASENAME). '": ' . $e ->getMessage()); } |
希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。
原文链接:https://blog.csdn.net/qq_42176520/article/details/80975353