用这种方法读取csv文件:
<?php
$file = fopen("contacts.csv","r");
while(! feof($file))
{
print_r(fgetcsv($file));
}
fclose($file);
?> 一下子把所有数据取出来了,文件的第一行是标题,第二行以后是要取的数据,怎么取?
还有读出的非英文字符显示为乱码,怎么处理?
用这种方法读取csv文件:
<?php
$file = fopen("contacts.csv","r");
while(! feof($file))
{
print_r(fgetcsv($file));
}
fclose($file);
?> 一下子把所有数据取出来了,文件的第一行是标题,第二行以后是要取的数据,怎么取?
还有读出的非英文字符显示为乱码,怎么处理?
1. while之前加一行 fgets($file);
2. 你的文件编码是啥,显示出来的应该是啥编码,搞清楚以后用iconv/mbstring转码一下就好了。
1.在页面最顶端加入:header("Content-type:text/html;charset=utf-8");
2.
<?php
$file = fopen("contacts.csv","r");
$data = fgetcsv($file);
while(! feof($file))
{
print_r($data = fgetcsv($file));
}
fclose($file);
?>
另一种方式:
$str = file_get_contents("contacts.csv");
$arr = explode("\n",$str);
print_r($arr[1]);
$file = fopen("contacts.csv", "r");
fgetcsv($file);
while(!feof($file) && $data = fgetcsv($file))
{
$csv_datas = array();
$csv_datas['column1'] = mb_convert_encoding($data[1], 'UTF-8', 'UTF-8,Shift_JIS');
// ...
}值得注意的是,第一列要加多余的列,真实数据从第二列才开始读得对,不知为什么。
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号