美文网首页PHP程序猿php相关PHP
PHP 读取/导出 CSV文件

PHP 读取/导出 CSV文件

作者: 新亮笔记 | 来源:发表于2016-07-22 09:37 被阅读342次
  • 工作中经常会有遇到导入/导出的需求,下面是常用的方法。
  • 读取CSV文件,可以分页读取,设置读取行数,起始行数即可。
  • 导出CSV文件,用两种方法进行实现。
/**
 * 读取CSV文件
 * @param string $csv_file csv文件路径
 * @param int $lines       读取行数
 * @param int $offset      起始行数
 * @return array|bool
 */
public function read_csv_lines($csv_file = '', $lines = 0, $offset = 0)
{
    if (!$fp = fopen($csv_file, 'r')) {
        return false;
    }
    $i = $j = 0;
    while (false !== ($line = fgets($fp))) {
        if ($i++ < $offset) {
            continue;
        }
        break;
    }
    $data = array();
    while (($j++ < $lines) && !feof($fp)) {
        $data[] = fgetcsv($fp);
    }
    fclose($fp);
    return $data;
}


/**
 * 导出CSV文件
 * @param array $data        数据
 * @param array $header_data 首行数据
 * @param string $file_name  文件名称
 * @return string
 */
public function export_csv_1($data = [], $header_data = [], $file_name = '')
{
    header('Content-Type: application/octet-stream');
    header('Content-Disposition: attachment; filename=' . $file_name);
    if (!empty($header_data)) {
        echo iconv('utf-8','gbk//TRANSLIT','"'.implode('","',$header_data).'"'."\n");
    }
    foreach ($data as $key => $value) {
        $output = array();
        $output[] = $value['id'];
        $output[] = $value['name'];
        echo iconv('utf-8','gbk//TRANSLIT','"'.implode('","', $output)."\"\n");
    }
}

/**
 * 导出CSV文件
 * @param array $data        数据
 * @param array $header_data 首行数据
 * @param string $file_name  文件名称
 * @return string
 */
public function export_csv_2($data = [], $header_data = [], $file_name = '')
{
    header('Content-Type: application/vnd.ms-excel');
    header('Content-Disposition: attachment;filename='.$file_name);
    header('Cache-Control: max-age=0');
    $fp = fopen('php://output', 'a');
    if (!empty($header_data)) {
        foreach ($header_data as $key => $value) {
            $header_data[$key] = iconv('utf-8', 'gbk', $value);
        }
        fputcsv($fp, $header_data);
    }
    $num = 0;
    //每隔$limit行,刷新一下输出buffer,不要太大,也不要太小
    $limit = 100000;
    //逐行取出数据,不浪费内存
    $count = count($data);
    if ($count > 0) {
        for ($i = 0; $i < $count; $i++) {
            $num++;
            //刷新一下输出buffer,防止由于数据过多造成问题
            if ($limit == $num) {
                ob_flush();
                flush();
                $num = 0;
            }
            $row = $data[$i];
            foreach ($row as $key => $value) {
                $row[$key] = iconv('utf-8', 'gbk', $value);
            }
            fputcsv($fp, $row);
        }
    }
    fclose($fp);
}

Thanks ~

AD:


PHP工程师订阅号

相关文章

  • Golang使用CSV读取、导出文件

    导出csv文件 读取csv

  • PHP 读取/导出 CSV文件

    工作中经常会有遇到导入/导出的需求,下面是常用的方法。 读取CSV文件,可以分页读取,设置读取行数,起始行数即可。...

  • PHP创建的csv文件在windows上乱码的问题

    前言 做PHP开发的时候,由于业务需要,可能要经常导出csv文件。使用PHP将数据导出到csv文件不难,使用fpu...

  • Matlab处理ILA数据

    在vivado中将ila数据导出成CSV文件格式保存。以下面的csv文件排列为例 MATLAB读取csv文件的代码...

  • 使用php导出csv文件

    使用php导出csv文件主要是有两个部分的内容: 按csv文件的格式准备好数据; php header() 函数,...

  • neo4j-批量导入工具使用

    从mysql中导出数据存储为csv文件 neo4j 数据库读取csv文件 读取但不存入数据库 读取并存入数据库,需...

  • csv文件的生成

    列表导出为csv文件 字典导出为csv文件 json导出为csv文件

  • 数据清洗

    一、数据的读取与导出 ①. 读取数据:txt、csv和xlsx文件 · 速度最慢 · 中等速度 · 速度最快 ②....

  • PHP 读取 CSV 文件

    导语 最近做了相关的功能,从 CSV 格式的文件中读取数据,然后进行操作,下面用实例代码记录下。 fgetcsv ...

  • php csv文件读取

    一开始只凭自己 的直觉编写了以下的代码: 其中 iconv('gb2312','utf-8',$line[0]);...

网友评论

    本文标题:PHP 读取/导出 CSV文件

    本文链接:https://www.haomeiwen.com/subject/mugmjttx.html