将 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() 函数将每个字段进行编码转换。最终的结果是一个二维数组,每个子数组都以列名为键值。