用PHPExcel插件读取文件实例

第一,下载PHPExcel文件。

第二,提出class文件夹里的文件。

第三,代码如下:

/**对excel里的日期进行格式转化*/

function GetData($date,$time = false){

$jd = GregorianToJD(1, 1, 1970);

$gregorian = JDToGregorian($jd+intval($date)-25569);

return $gregorian;/**显示格式为 “月/日/年” */

}

function excelTime($date, $time = false) {

if(function_exists('GregorianToJD')){

if (is_numeric( $date )) {

$jd = GregorianToJD( 1, 1, 1970 );

$gregorian = JDToGregorian( $jd + intval ( $date ) - 25569 );

$date = explode( '/', $gregorian );

$date_str = str_pad( $date [2], 4, '0', STR_PAD_LEFT )

."-". str_pad( $date [0], 2, '0', STR_PAD_LEFT )

."-". str_pad( $date [1], 2, '0', STR_PAD_LEFT )

. ($time ? " 00:00:00" : '');

return $date_str;

}

}else{

$date=$date>25568?$date+1:25569;

/*There was a bug if Converting date before 1-1-1970 (tstamp 0)*/

$ofs=(70 * 365 + 17+2) * 86400;

$date = date("Y-m-d",($date * 86400) - $ofs).($time ? " 00:00:00" : '');

}

return $date;

}

public function run($filePath){

//$filePath = 'ceshi.xls';

$PHPExcel = new PHPExcel();

/**默认用excel2007读取excel,若格式不对,则用之前的版本进行读取*/

$PHPReader = new PHPExcel_Reader_Excel2007();

if(!$PHPReader->canRead($filePath)){

$PHPReader = new PHPExcel_Reader_Excel5();

if(!$PHPReader->canRead($filePath)){

echo 'no Excel';

return ;

}

}

$PHPExcel = $PHPReader->load($filePath);

/**读取excel文件中的第一个工作表*/

$currentSheet = $PHPExcel->getSheet(0);

/**取得最大的列号*/

$allColumn = $currentSheet->getHighestColumn();

/**取得一共有多少行*/

$allRow = $currentSheet->getHighestRow();

//echo $allRow ;die;

/**从第二行开始输出,因为excel表中第一行为列名*/

for($currentRow = 2;$currentRow <= $allRow;$currentRow++){

/**从第A列开始输出*/

for($currentColumn= 'A';$currentColumn<= $allColumn; $currentColumn++){

$val = $currentSheet->getCellByColumnAndRow(ord($currentColumn) - 65,$currentRow)->getValue();/**ord()将字符转为十进制数*/

/**如果输出汉字有乱码,则需将输出内容用iconv函数进行编码转换,如下将gb2312编码转为utf-8编码输出*/

//iconv('utf-8','gb2312', $val)

if($currentColumn == 'A'){

$data[$currentRow]['name'] =$val;

}else if($currentColumn == 'B'){

$data[$currentRow]['password'] = $val;

}else if($currentColumn == 'C'){

$data[$currentRow]['facevalue'] = $val;

}else if($currentColumn == 'D'){

$data[$currentRow]['membertype'] = $val;

}else if($currentColumn == 'E'){

$data[$currentRow]['publisher'] = $val;

}else if($currentColumn == 'F'){

$data[$currentRow]['status'] = $val;

}else if($currentColumn == 'G'){

$data[$currentRow]['receipt'] = $val;

}else if($currentColumn == 'H'){

$data[$currentRow]['endtime'] =strtotime($this-> excelTime($val));

}

}

}

return $data;

}

public function test2(){

// $jj = GregorianToJD(1, 1, 1970);

// echo $jj;

// $arr = explode("/",$jj);

// echo $arr[0]."年".$arr[1]."月".$arr[2]."日";

}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 14,354评论 0 33
  • ¥开启¥ 【iAPP实现进入界面执行逐一显】 〖2017-08-25 15:22:14〗 《//首先开一个线程,因...
    小菜c阅读 11,855评论 0 17
  • 以下是常用的代码收集,学习用。转自豪情博客园 1. PC - js 返回指定范围的随机数(m-n之间)的公式 re...
    自由加咖啡阅读 4,640评论 0 1
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 32,323评论 18 399
  • 悠闲的午后被表妹拉出来逛街,走在温暖的阳光下,感觉睡意绵绵。 突然一个女人从街角的女装店里冲了出来,神情惊慌,左右...
    芃方阅读 3,034评论 3 4

友情链接更多精彩内容