php 将csv文件读取成数组 并以列明作为键值和处理中文乱码

将 CSV 文件读取成数组可以使用 PHP 内置的函数 str_getcsv() 或者 fgetcsv()

以下是使用 fgetcsv() 函数的示例代码:

$file = fopen('example.csv', 'r');

$keys = fgetcsv($file); // 获取列名作为键值

$data = array();

while (($row = fgetcsv($file)) !== false) {
    $data[] = array_combine($keys, $row);
}

fclose($file);

print_r($data);

需要注意的是,如果 CSV 文件中包含中文,则可能会出现乱码。解决方法是在打开文件时指定文件编码,并且在读取 CSV 文件时对每个字段进行编码转换。例如:

$file = fopen('example.csv', 'r');

// 指定文件编码为 GBK
stream_filter_append($file, 'convert.iconv.gbk/utf-8');

$keys = fgetcsv($file); // 获取列名作为键值

$data = array();

while (($row = fgetcsv($file)) !== false) {
    // 对每个字段进行编码转换
    $row = array_map('utf8_encode', $row);
    $data[] = array_combine($keys, $row);
}

fclose($file);

print_r($data);

其中,example.csv 是你要读取的 CSV 文件名,需要与当前 PHP 文件在同一目录下。代码中使用了 PHP 内置的函数 stream_filter_append() 将文件编码转换为 UTF-8,然后使用 fgetcsv() 函数逐行读取 CSV 文件,并通过 array_map() 函数将每个字段进行编码转换。最终的结果是一个二维数组,每个子数组都以列名为键值。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值