agentsib/csv-reader 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

agentsib/csv-reader

最新稳定版本:v1.0.1

Composer 安装命令:

composer require agentsib/csv-reader

包简介

Simple way read CSV file

关键字:

README 文档

README

Simple way read CSV file

Latest Stable Version Total Downloads Latest Unstable Version License

Installation

Install via composer:

composer require agentsib/csv-reader

Read CSV file with headers

Example file test.csv:

id;name;value 1;test1;value1 2;test2;value2 

Read file:

<? $resource = fopen('test.csv','r'); $csv = new AgentSIB\CsvReader\CsvReader($resource, true, ';'); // Get headers array $csv->getHeaders(); // ["id", "name", "value"] // Check header  $csv->hasHeader('id'); // true foreach ($csv as $row) { // Get value by column number echo $row[1]; // test1,test2 // Get value by column name echo $row['value']; // value1,value2 // Get value by not exists column echo $row['not_exists']; // null // Check value for exists isset($row[1]); // true isset($row[20]); // false isset($row['value']); //true isset($row['not_exists']); //false  } $csv->rewind(); $firstRow = $csv->current(); foreach ($firstRow as $key => $value) { echo $key.' => '.$value.PHP_EOL; } // id => 1 // name => test1 // value => value1 // Replace headers example $csv->replaceHeaders(['prop_id', 'prop_name', 'prop_value']); $csv->getHeaders(); // ['prop_id', 'prop_name', 'prop_value'] $csv->rewind(); $firstRow = $csv->current(); foreach ($firstRow as $key => $value) { echo $key.' => '.$value.PHP_EOL; } // prop_id => 1 // prop_name => test1 // prop_value => value1 // Replace headers example 2 $csv->replaceHeaders(['prop_id', 'prop_name']); $csv->getHeaders(); // ['prop_id', 'prop_name'] $csv->rewind(); $firstRow = $csv->current(); foreach ($firstRow as $key => $value) { echo $key.' => '.$value.PHP_EOL; } // prop_id => 1 // prop_name => test1

Read CSV file without headers

Example file test.csv:

1;test1;value1 2;test2;value2 

Read file:

<? $resource = fopen('test.csv','r'); $csv = new AgentSIB\CsvReader\CsvReader($resource, false, ';'); // Get headers array $csv->getHeaders(); // [] foreach ($csv as $row) { // Get value by column number echo $row[1]; // test1,test2 echo $row[20]; // null,null // Check value for exists isset($row[1]); // true isset($row[20]); // false } $csv->rewind(); $firstRow = $csv->current(); foreach ($firstRow as $key => $value) { echo $key.' => '.$value.PHP_EOL; } // 0 => 1 // 1 => test1 // 2 => value1 // Replace headers example $csv->replaceHeaders(['prop_id', 'prop_name', 'prop_value']); $csv->getHeaders(); // ['prop_id', 'prop_name', 'prop_value'] $csv->rewind(); $firstRow = $csv->current(); foreach ($firstRow as $key => $value) { echo $key.' => '.$value.PHP_EOL; } // prop_id => 1 // prop_name => test1 // prop_value => value1 // Replace headers example 2 $csv->replaceHeaders(['prop_id', 'prop_name']); $csv->getHeaders(); // ['prop_id', 'prop_name'] $csv->rewind(); $firstRow = $csv->current(); foreach ($firstRow as $key => $value) { echo $key.' => '.$value.PHP_EOL; } // prop_id => 1 // prop_name => test1

You can set headers on initialize:

<?php $resource = fopen('test.csv','r'); $csv = new AgentSIB\CsvReader\CsvReader($resource, ['id', 'name', 'value'], ';'); // Get headers array $csv->getHeaders(); // ['id', 'name', 'value'] $csv->rewind(); $firstRow = $csv->current(); foreach ($firstRow as $key => $value) { echo $key.' => '.$value.PHP_EOL; } // id => 1 // name => test1 // value => value1

Known issue

If you use stream php://input, you need save content to another stream, because rewind function not work in this case. For example:

<?php $resource = fopen('php://input', 'rb'); $r = fopen('php://memory', 'r+'); fwrite($r, stream_get_contents($resource)); rewind($r); $csv = new AgentSIB\CsvReader\CsvReader($r);

统计信息

  • 总下载量: 64.85k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 3
  • 点击次数: 3
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 3
  • Watchers: 1
  • Forks: 1
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-01-04

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固