PHP 读取Excel数据
涉及知识点:
对编码进行探测并检测
php对excel文件进行循环读取
php对字符进行ascii编码转化,将字符转为十进制数
php对excel日期格式读取,并进行显示转化
php对汉字乱码进行编码转化
<?php
require_once 'Classes/PHPExcel.php';
//探测字符串编码
function charset($haystack)
{
$chars = preg_replace('/([[:alnum:]]|[[:blank:]]|[[:space:]]|[[:punct:]])+/U', '', $haystack);
return mb_detect_encoding($chars, ['UTF-8', 'GB18030', 'BIG-5']);
}
//自动转换编码
function convert($haystack, $charset = 'UTF-8')
{
return mb_convert_encoding($haystack, $charset,charset($haystack));
}
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 <= $allRow;$currentRow++){
/**从第A列开始输出*/
for($currentColumn= 'A';$currentColumn<= $allColumn; $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 "</br>";
}
echo "\n";
?>
- PHP 读取Excel单元格中时间格式的数据
- php excel 读取日期问题 在 php excel 读取 xls 格式的文件时,xls 上面显示的是正常的日期格式 但是读取出来的话,就会是一个万位整形数据,这显然不是我们想要的日
- PHPExcel 读取文字+图片,保存数据,储存图片的例子
- phpexcel 读取数据
- PHP 从数据库Mysql中读取数据生成excel(解决乱码问题,解决中文变问号问题)
- 微擎php上传excel并且读取数据;保存到数据库
- phpexcel 读取数据
- phpExcel 读取数据,大数据文件处理方案
- phpexcel 读取数据
- phpexcel 读取含多个sheet的excel,将从数据库中检索出的数据分别写入该excel不同的sheet中 并导出该excel
- PHP-Excel读取导入Excel数据到数据库(2003,2007通用)使用方法
- phpexcel 读取中文gbk数据的csv在linux服务器下乱码的解决方法.
- phpexcel 读取数据
- phpexcel 读取数据
- PHP读取EXCEL时写入数据乱码解决办法
- PHP+MySQL连续插入数据报错:Commands out of sync; you can't run this command now & 读取Excel数据并批量插入到数据中
- php+phpspreadsheet读取Excel数据存入mysql
- phpExcel 读取数据,大数据文件处理方案
- PHP Excel 读取xls,xlsx文件并出入数据然后保存
- php 结合缓冲区读取excel数据并批量导入mysql