php读取csv文件时 用phpexcel很慢 用fgetcsv()函数中文乱码 请问还有啥excel库或函数方法来读csv文件吗
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了php读取csv文件时 用phpexcel很慢 用fgetcsv()函数中文乱码 请问还有啥excel库或函数方法来读csv文件吗相关的知识,希望对你有一定的参考价值。
最近需要用php读取csv文件并且显示在网页,然而用phpexcel读取csv和xls很慢(超过1M的文件加载会特别慢或者只读取一个A列),用fgetcsv()函数中文乱码(用网上的兼容编码代码也不行),请问还有什么excel库或函数方法来读取显示csv文件吗
参考技术Aphp从csv文件读取数据并输出到网页的方法
$fp = fopen('sample.csv','r') or die("can't open file");
print "<table>\\n";
while($csv_line = fgetcsv($fp))
print '<tr>';
for ($i = 0, $j = count($csv_line); $i < $j; $i++)
print '<td>'.htmlentities($csv_line[$i]).'</td>';
print "</tr>\\n";
print '</table>\\n';
fclose($fp) or die("can't close file");
?>
你可以这样试一试的啊
谢谢回复 试过了 windows电脑上用wps软件导出的表格是gbk 想要fgetcsv()显示中文就得先用iconv('GBK','UTF-8',$filename)转换编码为UTF-8在读取循环或者遍历输出 但是最后在前台显示的还是乱码中文...
(实用篇)PHPExcel读取Excel文件的实现代码
用PHPExcel读取Excel 2007 或者Excel2003文件,需要的朋友,可以参考下。
涉及知识点:
php对excel文件进行循环读取
php对字符进行ascii编码转化,将字符转为十进制数
php对excel日期格式读取,并进行显示转化
php对汉字乱码进行编码转化
<?php
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读取csv文件时 用phpexcel很慢 用fgetcsv()函数中文乱码 请问还有啥excel库或函数方法来读csv文件吗的主要内容,如果未能解决你的问题,请参考以下文章