PHPExcel(1)エクスポート関数

WBOY
WBOYオリジナル
2016-06-23 13:35:001126ブラウズ

PHPExcel エクスポート機能

Web を開発するとき、データベース内の特定のフォームを Excel ファイルにエクスポートする必要があるという問題によく遭遇します。 Web 開発に yii フレームワークを使用していたときに、Excel ファイルをインポートおよびエクスポートできる PHPExcel というアプリケーションを見つけました。これは必要な要件を満たしています。以下は、PHPExcel を使用してデータをエクスポートした記録です。

1. まずアプリケーションをダウンロードします。github リンクは次のとおりです: https://github.com/PHPOffice/PHPExcel

2. protected/extensions パスの下に PHPexcel ディレクトリを作成し、ダウンロードした PHPExcel ファイルを解凍します。

3. 解凍したクラス ディレクトリのすべての内容を protected/extensions/PHPexcel ディレクトリにコピーします

4. コントローラー ファイル XXX.Controller.php に、最初に関連ファイルを導入します

<?phpYii::import('application.extensions.*');require_once('PHPExcel/PHPExcel.php');require_once 'PHPExcel/PHPExcel/Writer/Excel5.php'; // 用于其他低版本xlsrequire_once 'PHPExcel/PHPExcel/Writer/Excel2007.php'; // 用于 excel-2007 格式...


5. Write Method Download (以下は私自身の開発プロセスのコードの一部です)
public function actionDownload($option)    {        // Create new PHPExcel object        $objPHPExcel = new PHPExcel();        // Set properties        $objPHPExcel->getProperties()->setCreator("Maarten Balliauw")            ->setLastModifiedBy("Maarten Balliauw")            ->setTitle("Office 2007 XLSX Test Document")            ->setSubject("Office 2007 XLSX Test Document")            ->setDescription("Test document for Office 2007 XLSX, generated using PHP classes.")            ->setKeywords("office 2007 openxml php")            ->setCategory("Test result file");        //$objPHPExcel->getActiveSheet()->mergeCells('A1:G1');        //$objPHPExcel->getActiveSheet()->getStyle('A1')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER);        //$objPHPExcel->getActiveSheet()->getColumnDimension('C')->setAutoSize(true);        //$objPHPExcel->getActiveSheet()->getColumnDimension('A')->setWidth(20);        //$objPHPExcel->getActiveSheet()->getColumnDimension('E')->setWidth(20);        $subjects = Subject::model()->findAll("headteacher=:name", array(":name" => Yii::app()->session['name'])); //找出相关课程组        foreach ($subjects as $item1) {            $criteria = new CDbCriteria; // 创建CDbCriteria对象            $criteria->addCondition("suid = :id");            $criteria->params[':id'] = $item1->id;            $criteria->select = '*';            //按照返回参数搜索选题信息            if ($option == 1) {                $criteria->order = 'Cid';                //$criteria -> limit = 3;                $b = Selectcourse::model()->findAll($criteria);                $objPHPExcel->setActiveSheetIndex(0)                    ->setCellValue('A1', '选题情况')                    ->setCellValue('A2', '学生ID')                    ->setCellValue('B2', '学生姓名')                    ->setCellValue('C2', '课程名称')                    ->setCellValue('D2', '题目名称')                    ->setCellValue('E2', '选题时间');                $count = 2;                foreach ($b as $item2) {                    $count += 1;                    $l1 = "A" . "$count";                    $l2 = "B" . "$count";                    $l3 = "C" . "$count";                    $l4 = "D" . "$count";                    $l5 = "E" . "$count";                    $objPHPExcel->setActiveSheetIndex(0)                        ->setCellValue($l1, $item2->sid)                        ->setCellValue($l2, Student::model()->find(array('condition' => 'id=' . $item2->sid,))->name)                        ->setCellValue($l3, $item1->name)                        ->setCellValue($l4, Course::model()->find(array('condition' => 'Cid=' . $item2->cid,))->Cname)                        ->setCellValue($l5, $item2->apply_time);                }            }            if ($option == 2) {                $criteria->order = 'sid';                //$criteria -> limit = 3;                $b = Selectcourse::model()->findAll($criteria);                $objPHPExcel->setActiveSheetIndex(0)                    ->setCellValue('A1', '选题情况')                    ->setCellValue('A2', '学生ID')                    ->setCellValue('B2', '学生姓名')                    ->setCellValue('C2', '课程名称')                    ->setCellValue('D2', '题目名称')                    ->setCellValue('E2', '选题时间');                $count = 2;                foreach ($b as $item2) {                    $count += 1;                    $l1 = "A" . "$count";                    $l2 = "B" . "$count";                    $l3 = "C" . "$count";                    $l4 = "D" . "$count";                    $l5 = "E" . "$count";                    $objPHPExcel->setActiveSheetIndex(0)                        ->setCellValue($l1, $item2->sid)                        ->setCellValue($l2, Student::model()->find(array('condition' => 'id=' . $item2->sid,))->name)                        ->setCellValue($l3, $item1->name)                        ->setCellValue($l4, Course::model()->find(array('condition' => 'Cid=' . $item2->cid,))->Cname)                        ->setCellValue($l5, $item2->apply_time);                }            }        }        // Rename sheet        $objPHPExcel->getActiveSheet()->setTitle('学生选题信息');        // Set active sheet index to the first sheet, so Excel opens this as the first sheet        $objPHPExcel->setActiveSheetIndex(0);        // Redirect output to a client’s web browser (Excel5)        header('Content-Type: application/vnd.ms-excel');        header('Content-Disposition: attachment;filename="学生选题信息.xls"');        header('Cache-Control: max-age=0');        $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');        $objWriter->save('php://output');    }



6. ユーザーアクセス制御にダウンロードアクションを追加することを忘れないでください
public function accessRules(){array('allow', // allow admin user to perform 'admin' and 'delete' actions                'actions' => array('download'),                'roles' => array('...'),            ),}



7. 対応するビューファイルにリンクを書き込みます
<?php echo CHtml::link(CHtml::encode("》导出Excel表格"), array('download','option' => $option)); ?>



8. Excel ファイルとしてデータのエクスポートを完了します。


上記は私の PHPExcel のアプリケーションです。初めて使用するため、使用に習熟していないため、間違いがいくつかあると思います。皆さんに指摘してもらい、一緒に進歩していただければ幸いです。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。