定制 oppara/csv_simple 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

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

oppara/csv_simple

最新稳定版本:0.0.8

Composer 安装命令:

composer require oppara/csv_simple

包简介

CakePHP plugin which handle csv data

关键字:

README 文档

README

Build Status

handle csv data

Requirements

  • PHP >= 5.5
  • CakePHP >= 2.6

Installation

composer.json

{
    "require": {
        "oppara/csv_simple": "*"
    }
}

Enable plugin

app/Config/bootstrap.php:

CakePlugin::load('CsvSimple'); or CakePlugin::loadAll();

Sample

<?php
App::uses('AppController', 'Controller');
App::uses('CsvImportComponent', 'CsvSimple.Controller/Component');
App::uses('CsvExportComponent', 'CsvSimple.Controller/Component');

class FooController extends AppController
{
    public $components = [
        'CsvSimple.CsvImport',
        'CsvSimple.CsvExport',
    ];

    public $uses = [
        'Bar',
    ];

    public function import()
    {
        if ($this->request->is('get')) {
            return;
        }

        try {
            $csv = Hash::get($this->request->data, 'Csv.file');

            $this->CsvImport->headerRows = 1;
            $gen = $this->CsvImport->createGenerator($csv);

            $this->Bar->begin();
            foreach ($gen as $idx => $row) {
                $this->Bar->import($row);
            }
            $this->Bar->commit();
        }
        catch(Exception$e) {
            $this->Bar->rollback();
            $this->set('error', $e->getMessage());
        }
    }

    public function download()
    {
        try {
            $filename = date('Ymdhis') . '.tsv';
            $this->CsvExport->delimiter = "\t";

            $data = $this->Bar->find('all');
            $this->CsvExport->download($data, $filename);
        }
        catch(Exception$e) {
            $this->set('error', $e->getMessage());
        }
    }

    public function export()
    {
        try {
            $path = '/path/to/export.csv';

            $fields = $this->Bar->getHeaderFields();
            $this->CsvExport->setHeader($fields);

            $data = $this->Bar->find('all');
            $this->CsvExport->export($data, $path);
        }
        catch(Exception$e) {
            $this->set('error', $e->getMessage());
        }
    }

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2015-10-21