PHPエクスポートレポート(事例)
効果
要件
レポート効果を達成するために、私は独自の要件を作成しました。
それは主にアイデアに関するものです。アイデアが明確になると、他の効果も達成できます。
一年中毎日、何人が遅刻して早退するかに関する統計。
アイデア
PHP言語を使用して実装します。
最初に HTML を使用してレポート スタイルを実装し、
次に PHP ヘッダー関数を使用して xls ダウンロードを生成します。
知識ポイント
テーブルの列結合と行結合
PHP 一年中毎日取得して表示
PHPヘッダー関数
Smartyテンプレート関数
定義以来function
...
PHP code
public function export() { //获取2016年日期 $time_start = strtotime('2016-01-01'); $time_end = strtotime('2016-12-31'); $month_arr = []; $month_arr['month'][] = '2016-01'; $month_arr['numbers'][] = date('t',$time_start); //获取天数 while (($time_start = strtotime('+1 month', $time_start)) <= $time_end) { $month_arr['month'][] = date('Y-m',$time_start); //取得递增月 $month_arr['numbers'][] = date('t',$time_start); //获取天数 } function check_week($time = []) { if (empty($time['day'])) { return ''; } $w = intval(date('w' , strtotime($time['day']))); if( $w === 0 || $w === 6){ return '<td style="background-color: red;">' .date('d', strtotime($time['day'])) .'</td>'; } return '<td>'.date('d', strtotime($time['day'])).'</td>'; } //向模板中注册一个函数 $this->smarty->registerPlugin('function','check_week','check_week'); //模拟数据如下: $list[0]['name'] = 'Tom'; $list[1]['name'] = 'Joan'; $list[0]['sex'] = '男'; $list[1]['sex'] = '女'; $list[0]['age'] = '30'; $list[1]['age'] = '31'; //设置迟到 $list[0]['late'] = [ '2016-01-08', '2016-01-09', '2016-02-09', '2016-03-09', '2016-04-09', '2016-05-09' ]; $list[1]['late'] = [ '2016-02-12', '2016-03-15', '2016-04-13', '2016-05-19', '2016-05-19' ]; //设置早退 $list[0]['leave'] = [ '2016-03-09', '2016-04-11', '2016-05-15', '2016-06-18', '2016-07-21', '2016-08-23', '2016-09-22', '2016-10-20', '2016-11-17', '2016-12-14', ]; $list[1]['leave'] = [ '2016-05-09', '2016-06-11', '2016-07-13', '2016-08-15', '2016-09-17', '2016-10-19', '2016-11-20', '2016-12-23', '2016-03-18', '2016-02-19', '2016-01-23', ]; $file_name = "报表-".date("YmdHis",time()); $file_suffix = "xls"; header("Content-Type: application/vnd.ms-excel"); header("Content-Disposition: attachment; filename=$file_name.$file_suffix"); $this->_assign('list', $list); $this->_assign('month', $month_arr); $this->_display(); }
HTML code
<html xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:x="urn:schemas-microsoft-com:office:excel" xmlns="http://www.w3.org/TR/REC-html40"> <head> <meta http-equiv=Content-Type content="text/html; charset=utf-8"> <meta name=ProgId content=Excel.Sheet> <meta name=Generator content="Microsoft Excel 11"> </head> <body> <table border=1 cellpadding=0 cellspacing=0 width="100%"> <tr> <td style="vertical-align:middle;" align="center" rowspan="2"> <b>姓名</b> </td> <td style="vertical-align:middle;" align="center" rowspan="2"> <b>性别</b> </td> <td style="vertical-align:middle;" align="center" rowspan="2"> <b>年龄</b> </td> {if $month} {foreach $month.month as $k=>$m} <td style="text-align: center;" colspan="{$month.numbers.$k}"> <b>{$m}</b> </td> {/foreach} {/if} </tr> <tr> {if $month} {foreach $month.month as $k=>$m} {section name=count loop=$month.numbers.$k+1 start=1} {check_week day=$m|cat:"-"|cat:$smarty.section.count.index} {/section} {/foreach} {/if} </tr> {if $list} {foreach $list as $s} <tr> <td>{$s.name|default:'--'}</td> <td>{$s.sex|default:'--'}</td> <td>{$s.age|default:'--'}</td> {if $month} {foreach $month.month as $k=>$m} {section name=count loop=$month.numbers.$k+1 start=1} {if $smarty.section.count.index <10 } {$str = ""} {$smarty.section.count.index = $str|cat:"0"|cat:$smarty.section.count.index} {/if} <td style=" {if $s['late']} {if ($m|cat:"-"|cat:$smarty.section.count.index)|in_array:$s['late']} background-color: #5a0099; {/if} {/if} {if $s['leave']} {if ($m|cat:"-"|cat:$smarty.section.count.index)|in_array:$s['leave']} background-color: yellow; {/if} {/if} "> {if $s['late']} {if ($m|cat:"-"|cat:$smarty.section.count.index)|in_array:$s['late']} 1 {/if} {/if} {if $s['leave']} {if ($m|cat:"-"|cat:$smarty.section.count.index)|in_array:$s['leave']} 1 {/if} {/if} </td> {/section} {/foreach} {/if} </tr> {/foreach} <tr> <td style="background-color: red"></td> <td>*周末</td> </tr> <tr> <td style="background-color: white"></td> <td>*正常</td> </tr> <tr> <td style="background-color: #5a0099"></td> <td>*迟到</td> </tr> <tr> <td style="background-color: yellow"></td> <td>*早退</td> </tr> {/if} </table> </body> </html>
上記は、PHP 輸出レポート (事例) の内容です。詳細については、PHP 中国語 Web サイト ( www.php.cn)!

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











PHP 8.4 では、いくつかの新機能、セキュリティの改善、パフォーマンスの改善が行われ、かなりの量の機能の非推奨と削除が行われています。 このガイドでは、Ubuntu、Debian、またはその派生版に PHP 8.4 をインストールする方法、または PHP 8.4 にアップグレードする方法について説明します。

あなたが経験豊富な PHP 開発者であれば、すでにそこにいて、すでにそれを行っていると感じているかもしれません。あなたは、運用を達成するために、かなりの数のアプリケーションを開発し、数百万行のコードをデバッグし、大量のスクリプトを微調整してきました。

Visual Studio Code (VS Code とも呼ばれる) は、すべての主要なオペレーティング システムで利用できる無料のソース コード エディター (統合開発環境 (IDE)) です。 多くのプログラミング言語の拡張機能の大規模なコレクションを備えた VS Code は、

JWTは、JSONに基づくオープン標準であり、主にアイデンティティ認証と情報交換のために、当事者間で情報を安全に送信するために使用されます。 1。JWTは、ヘッダー、ペイロード、署名の3つの部分で構成されています。 2。JWTの実用的な原則には、JWTの生成、JWTの検証、ペイロードの解析という3つのステップが含まれます。 3. PHPでの認証にJWTを使用する場合、JWTを生成および検証でき、ユーザーの役割と許可情報を高度な使用に含めることができます。 4.一般的なエラーには、署名検証障害、トークンの有効期限、およびペイロードが大きくなります。デバッグスキルには、デバッグツールの使用とロギングが含まれます。 5.パフォーマンスの最適化とベストプラクティスには、適切な署名アルゴリズムの使用、有効期間を合理的に設定することが含まれます。

文字列は、文字、数字、シンボルを含む一連の文字です。このチュートリアルでは、さまざまな方法を使用してPHPの特定の文字列内の母音の数を計算する方法を学びます。英語の母音は、a、e、i、o、u、そしてそれらは大文字または小文字である可能性があります。 母音とは何ですか? 母音は、特定の発音を表すアルファベットのある文字です。大文字と小文字など、英語には5つの母音があります。 a、e、i、o、u 例1 入力:string = "tutorialspoint" 出力:6 説明する 文字列「TutorialSpoint」の母音は、u、o、i、a、o、iです。合計で6元があります

このチュートリアルでは、PHPを使用してXMLドキュメントを効率的に処理する方法を示しています。 XML(拡張可能なマークアップ言語)は、人間の読みやすさとマシン解析の両方に合わせて設計された多用途のテキストベースのマークアップ言語です。一般的にデータストレージに使用されます

静的結合(静的::) PHPで後期静的結合(LSB)を実装し、クラスを定義するのではなく、静的コンテキストで呼び出しクラスを参照できるようにします。 1)解析プロセスは実行時に実行されます。2)継承関係のコールクラスを検索します。3)パフォーマンスオーバーヘッドをもたらす可能性があります。

PHPの魔法の方法は何ですか? PHPの魔法の方法には次のものが含まれます。1。\ _ \ _コンストラクト、オブジェクトの初期化に使用されます。 2。\ _ \ _リソースのクリーンアップに使用される破壊。 3。\ _ \ _呼び出し、存在しないメソッド呼び出しを処理します。 4。\ _ \ _ get、dynamic属性アクセスを実装します。 5。\ _ \ _セット、動的属性設定を実装します。これらの方法は、特定の状況で自動的に呼び出され、コードの柔軟性と効率を向上させます。
