>  기사  >  백엔드 개발  >  PHPExcel读取Excel文件_PHP教程

PHPExcel读取Excel文件_PHP教程

WBOY
WBOY원래의
2016-07-13 17:47:38766검색

 

用PHPExcel读取Excel 2007 或者Excel2003文件

涉及知识点:www.2cto.com

php对excel文件进行循环读取

php对字符进行ascii编码转化,将字符转为十进制数

php对excel日期格式读取,并进行显示转化

php对汉字乱码进行编码转化

  View Code

 

require_once 'PHPExcel.php';

 

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

function GetData($val){

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

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

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

}

 

$filePath = 'test.xlsx';

 

$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();

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

for($currentRow = 2;$currentRow

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

    for($currentColumn= 'A';$currentColumn

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

        if($currentColumn == 'A')

        {

            echo GetData($val)."\t";

        }else{

            //echo $val;

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

            echo iconv('utf-8','gb2312', $val)."\t";

        }

    }

    echo "";

}

echo "\n";

?>

 

摘自 片片云飘过

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/478504.htmlTechArticle用PHPExcel读取Excel 2007 或者Excel2003文件 涉及知识点:www.2cto.com php对excel文件进行循环读取 php对字符进行ascii编码转化,将字符转为十进制数...
성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.