主頁 > 知識(shí)庫 > Yii框架中使用PHPExcel的方法分析

Yii框架中使用PHPExcel的方法分析

熱門標(biāo)簽:怎么向銷售公司推銷外呼系統(tǒng) 仁和怎么申請(qǐng)400開頭的電話 長春人工外呼系統(tǒng)服務(wù)商 廣東地市地圖標(biāo)注 廣州防封卡外呼系統(tǒng)多少錢一個(gè)月 高德地圖標(biāo)注家 外呼系統(tǒng)撥打暫時(shí)無法接通 江西手機(jī)自動(dòng)外呼防封系統(tǒng)是什么 哪里辦理400電話

本文實(shí)例分析了Yii框架中使用PHPExcel的方法。分享給大家供大家參考,具體如下:

PHPExcel是一個(gè)比較好用的php讀取excel文件的類庫,今天遇到了在yii中如何加載PHPExcel類文件的問題,因?yàn)閅ii的autoload機(jī)制是安裝類名去找文件,即文件名就是相應(yīng)的類名,而PHPExcel的類文件命名方式則是:dir_dir_classname.php,即文件名把文件的目錄名都記錄了,這種命名方式y(tǒng)ii肯定識(shí)別不了。怎么辦?

其實(shí)PHPExcel也有自己的autoload方法(PHPExcel_Autoloader::load() ),通過查看源碼發(fā)現(xiàn)它也是通過spl_autoload_register函數(shù)注冊(cè)的(在PHPExcel_Autoloader::register() 中),而我們知道PHP的autoload機(jī)制是,所有用spl_autoload_register函數(shù)注冊(cè)的方法,都會(huì)在autoload時(shí)被spl_autoload_call函數(shù)執(zhí)行一遍,因此我們只需要讓PHPExcel的autoload方法順利注冊(cè)上就行了。

如果了解Yii的autoload機(jī)制,不清楚的可以看 附錄 Yii的autoload機(jī)制 ,可以知道,只要設(shè)置Yii::$enableIncludePathfalse,第三方類庫就有了執(zhí)行自己的autoload方法的機(jī)會(huì),然后使用下面兩行代碼就能加載PHPExcel的類了:

Yii::$enableIncludePath = false;
Yii::import('application.vendors.phpexcel.PHPExcel', 1);

import時(shí)采用了force include的方式,這是因?yàn)镻HPExcel.php在被require時(shí)才會(huì)注冊(cè)autoloader,如果等到new PHPExcel時(shí)才注冊(cè),其他的類例如PHPExcel_IOFactory如果在這之前使用了,就會(huì)出現(xiàn)找不到類的錯(cuò)誤。

個(gè)人認(rèn)為我的這種辦法是比較方便且優(yōu)雅的,對(duì)比網(wǎng)上的其他辦法好很多,下面列舉的辦法都或多或少有點(diǎn)問題,例如:

1、https://www.jb51.net/article/166128.htm,這種辦法先將Yii自己的autoloader unregister了,會(huì)造成yii自己的類加載不上

2、https://www.jb51.net/article/166132.htm,這種辦法還修改了PHPExcel的autoloader,代價(jià)很大。

附錄: Yii的autoload機(jī)制

Yii框架宣稱自己的類加載方式很高效,是真正的“用時(shí)加載”,那究竟特別在哪里?今天研究了一下源碼,發(fā)現(xiàn)其實(shí)是在代碼級(jí)加了一層“路徑緩存”。

我們知道,要實(shí)現(xiàn)自己的autoload方法,需要采用spl_autoload_register()函數(shù)注冊(cè)一個(gè)autoload方法,Yii注冊(cè)的這個(gè)方法是YiiBase::autoload(),稍后再講解這個(gè)方法的邏輯。另外,Yii一般都用Yii::import($pathAlias, $forceInclude=false)來加載相應(yīng)的類(這個(gè)方法直接調(diào)用了YiiBase::import() ),這個(gè)方法配合YiiBase::autoload()就能實(shí)現(xiàn)“用時(shí)加載”了。

先說import的大致邏輯:

1、檢查self::$_imports數(shù)組是否存在相應(yīng)的$pathAlias,如果有說明已經(jīng)加載過了,直接返回類名或者目錄名;否則繼續(xù)第2步;

2、根據(jù)路徑別名獲得實(shí)際的路徑名,并根據(jù)路徑別名最后一部分是否是“*”可以知道要加載的路徑別名是否是一個(gè)文件,如果是文件,去第3步;否則去第4步;

3、如果是$forceInclude是true,則立即require這個(gè)文件,并在$_imports數(shù)組中增加一項(xiàng)$alias => $className;否則在數(shù)組$classMap中緩存一項(xiàng)$className => $realPath

4、對(duì)于路徑,會(huì)在數(shù)組$_includePaths中緩存這個(gè)路徑,并且在$_imports數(shù)組中增加一項(xiàng)$alias => $realPath

5、結(jié)束。

因?yàn)?forceInclude默認(rèn)都為false,所以import不會(huì)立即加載相應(yīng)的類,等到使用時(shí)才真正加載,這是YiiBase::autoload的工作。

autoload的大致邏輯:

1、檢查類名是否已緩存在$classMap或$_coreClasses數(shù)組中,如果是則直接require相應(yīng)的文件路徑,$_coreClasses是框架自有類的映射表;否則去第2步;

2、檢測YiiBase::$enableIncludePath是否為false,如果是則去第3步,否則直接include($className . '.php')

3、遍歷$includePaths數(shù)組,將目錄名拼接上類名,檢查是否為合法的php文件,如果是則include,然后跳出循環(huán)

4、結(jié)束。

需要注意的是,文檔指出:如果要與其他類庫一起使用,必須將$enableIncludePath置為false,以便在Yii::autoload()失敗時(shí),其他類庫的autoload方法有機(jī)會(huì)執(zhí)行。

更多關(guān)于Yii相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Yii框架入門及常用技巧總結(jié)》、《php優(yōu)秀開發(fā)框架總結(jié)》、《smarty模板入門基礎(chǔ)教程》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》

希望本文所述對(duì)大家基于Yii框架的PHP程序設(shè)計(jì)有所幫助。

您可能感興趣的文章:
  • Yii框架使用PHPExcel導(dǎo)出Excel文件的方法分析【改進(jìn)版】
  • yii框架redis結(jié)合php實(shí)現(xiàn)秒殺效果(實(shí)例代碼)
  • 詳解PHP的Yii框架中擴(kuò)展的安裝與使用
  • 詳解PHP的Yii框架中自帶的前端資源包的使用
  • php中yii框架實(shí)例用法

標(biāo)簽:惠州 廈門 黔東 湘西 濮陽 海北 梅河口 文山

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Yii框架中使用PHPExcel的方法分析》,本文關(guān)鍵詞  Yii,框架,中,使用,PHPExcel,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Yii框架中使用PHPExcel的方法分析》相關(guān)的同類信息!
  • 本頁收集關(guān)于Yii框架中使用PHPExcel的方法分析的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章