2023-12-02 分類: 網(wǎng)站建設(shè)
實現(xiàn)pHp生成word文檔的三種方法
更新時間:2016年11月14日14:13:09 作者:pHp淮北
本文主要介紹pHp生成word的三種實現(xiàn)方法。使用 pHp 將內(nèi)容寫入 Word。如果需要,可以了解一下。
最近在工作中遇到了生詞問題
現(xiàn)在總結(jié)一下生成詞的三種方法。
btw:只要標(biāo)題有pHp,好像點擊量不是很高(兄弟,我標(biāo)題里還有pHp),不知道為什么,估計是網(wǎng)多了博客園的技術(shù)專家。如果你用java、.net、php就像程序員的女朋友,那么java就是家底最好的姑娘,.net微軟底下的名門,pHp就是草根下的狂野阿姨。這讓我等著pHp草民們?nèi)コ惺苓@份情意。 投訴完了,正式寫起來
pHp生成詞的原理
具體實現(xiàn):
使用下面的com組件
原理:com是pHp的擴(kuò)展。安裝好的服務(wù)器會自動調(diào)用word。 com,可以自動生成文檔。 pHp官方文檔手冊:
使用官方示例:
Version}\n"; //bring it to front $word->Visible = 1; //open an empty document $word->Documents->Add(); //do some weird stuff $word->Selection->TypeText("This is a test..."); $word->Documents[1]->SaveAs("Useless test.doc"); //closing word $word->Quit(); //free the object $word = null; ?>
個人建議:com實例后面的所有方法都需要查官方文檔才知道是什么意思。編輯器沒有代碼提示,非常不方便。另外這個效率不是很高,所以不推薦。
使用 pHp 將內(nèi)容寫入 doc 文件
這個方法可以分為兩種方法。
生成mht格式(類似HTML)并寫字
/** * 根據(jù)HTML代碼獲取word文檔內(nèi)容 * 創(chuàng)建一個本質(zhì)為mht的文檔,該函數(shù)會分析文件內(nèi)容并從遠(yuǎn)程下載頁面中的圖片資源 * 該函數(shù)依賴于類MhtFileMaker * 該函數(shù)會分析img標(biāo)簽,提取src的屬性值。但是,src的屬性值必須被引號包圍,否則不能提取 * * @param string $content HTML內(nèi)容 * @param string $absolutepath 網(wǎng)頁的絕對路徑。如果HTML內(nèi)容里的圖片路徑為相對路徑,那么就需要填寫這個參數(shù),來讓該函數(shù)自動填補(bǔ)成絕對路徑。這個參數(shù)最后需要以/結(jié)束 * @param bool $isEraseLink 是否去掉HTML內(nèi)容中的鏈接 */ function getWordDocument( $content , $absolutepath = "" , $isEraseLink = true ) { $mht = new MhtFileMaker(); if ($isEraseLink) $content = preg_replace('/(\s*.*?\s*)<\/a>/i' , '$1' , $content); //去掉鏈接 $images = array(); $files = array(); $matches = array(); //這個算法要求src后的屬性值必須使用引號括起來 if ( preg_match_all('//i',$content ,$matches ) ) { $arrpath = $matches[1]; for ( $i=0;$iAddContents("tmp.html",$mht->GetMimeType("tmp.html"),$content); for ( $i=0;$i AddContents($files[$i],$mht->GetMimeType($image),$imgcontent); } else { echo "file:".$image." not exist!
"; } } return $mht->GetFile(); }
這個函數(shù)的主要作用其實就是分析HTML代碼中的所有圖片地址,依次下載。獲取到圖片內(nèi)容后php導(dǎo)出word格式數(shù)據(jù)的實現(xiàn)代碼,調(diào)用類將圖片添加到mht文件中。具體的添加細(xì)節(jié)封裝在類中。
使用方法:遠(yuǎn)程調(diào)用
url= http://www.***.com; $content = file_get_contents($url); $fileContent = getWordDocument($content,"https://www.jb51.net/Music/etc/"); $fp = fopen("test.doc", 'w'); fwrite($fp, $fileContent); fclose($fp);
其中$變量應(yīng)該是HTML源代碼,下面的鏈接應(yīng)該是可以在HTML代碼中填寫圖片相對路徑的URL地址
本地生成調(diào)用:
header("Cache-Control: no-cache, must-revalidate"); header("pragma: no-cache"); $wordStr = 'https://www.jb51.net/'; $fileContent = getWordDocument($wordStr); $fileName = iconv("utf-8", "GbK", ‘jb51' . '_'. $intro . '_' . rand(100, 999)); header("Content-Type: application/doc"); header("Content-Disposition: attachment; filename=" . $fileName . ".doc"); echo $fileContent;
注意在使用這個函數(shù)之前php導(dǎo)出word格式數(shù)據(jù)的實現(xiàn)代碼,需要先包含這個類,這個類可以幫助我們生成Mht文檔。
headers[] = $header; $key = strtolower(substr($header, 0, strpos($header, ':'))); $this->headers_exists[$key] = TRUE; } function SetFrom($from){ $this->SetHeader("From: $from"); } function SetSubject($subject){ $this->SetHeader("Subject: $subject"); } function SetDate($date = NULL, $istimestamp = FALSE){ if ($date == NULL) { $date = time(); } if ($istimestamp == TRUE) { $date = date('D, d M Y H:i:s O', $date); } $this->SetHeader("Date: $date"); } function Setboundary($boundary = NULL){ if ($boundary == NULL) { $this->boundary = '--' . strtoupper(md5(mt_rand())) . '_MULTIpART_MIXED'; } else { $this->boundary = $boundary; } } function SetbaseDir($dir){ $this->dir_base = str_replace("\\", "/", realpath($dir)); } function SetFirstpage($filename){ $this->page_first = str_replace("\\", "/", realpath("{$this->dir_base}/$filename")); } function AutoAddFiles(){ if (!isset($this->page_first)) { exit ('Not set the first page.'); } $filepath = str_replace($this->dir_base, '', $this->page_first); $filepath = 'http://mhtfile' . $filepath; $this->AddFile($this->page_first, $filepath, NULL); $this->AddDir($this->dir_base); } function AddDir($dir){ $handle_dir = opendir($dir); while ($filename = readdir($handle_dir)) { if (($filename!='.') && ($filename!='..') && ("$dir/$filename"!=$this->page_first)) { if (is_dir("$dir/$filename")) { $this->AddDir("$dir/$filename"); } elseif (is_file("$dir/$filename")) { $filepath = str_replace($this->dir_base, '', "$dir/$filename"); $filepath = 'http://mhtfile' . $filepath; $this->AddFile("$dir/$filename", $filepath, NULL); } } } closedir($handle_dir); } function AddFile($filename, $filepath = NULL, $encoding = NULL){ if ($filepath == NULL) { $filepath = $filename; } $mimetype = $this->GetMimeType($filename); $filecont = file_get_contents($filename); $this->AddContents($filepath, $mimetype, $filecont, $encoding); } function AddContents($filepath, $mimetype, $filecont, $encoding = NULL){ if ($encoding == NULL) { $filecont = chunk_split(base64_encode($filecont), 76); $encoding = 'base64'; } $this->files[] = array('filepath' => $filepath, 'mimetype' => $mimetype, 'filecont' => $filecont, 'encoding' => $encoding); } function CheckHeaders(){ if (!array_key_exists('date', $this->headers_exists)) { $this->SetDate(NULL, TRUE); } if ($this->boundary == NULL) { $this->Setboundary(); } } function CheckFiles(){ if (count($this->files) == 0) { return FALSE; } else { return TRUE; } } function GetFile(){ $this->CheckHeaders(); if (!$this->CheckFiles()) { exit ('No file was added.'); } $contents = implode("\r\n", $this->headers); $contents .= "\r\n"; $contents .= "MIME-Version: 1.0\r\n"; $contents .= "Content-Type: multipart/related;\r\n"; $contents .= "\tboundary=\"{$this->boundary}\";\r\n"; $contents .= "\ttype=\"" . $this->files[0]['mimetype'] . "\"\r\n"; $contents .= "X-MimeOLE: produced by Mht File Maker v1.0 beta\r\n"; $contents .= "\r\n"; $contents .= "This is a multi-part message in MIME format.\r\n"; $contents .= "\r\n"; foreach ($this->files as $file) { $contents .= "--{$this->boundary}\r\n"; $contents .= "Content-Type: $file[mimetype]\r\n"; $contents .= "Content-Transfer-Encoding: $file[encoding]\r\n"; $contents .= "Content-Location: $file[filepath]\r\n"; $contents .= "\r\n"; $contents .= $file['filecont']; $contents .= "\r\n"; } $contents .= "--{$this->boundary}--\r\n"; return $contents; } function MakeFile($filename){ $contents = $this->GetFile(); $fp = fopen($filename, 'w'); fwrite($fp, $contents); fclose($fp); } function GetMimeType($filename){ $pathinfo = pathinfo($filename); switch ($pathinfo['extension']) { case 'htm': $mimetype = 'text/html'; break; case 'html': $mimetype = 'text/html'; break; case 'txt': $mimetype = 'text/plain'; break; case 'cgi': $mimetype = 'text/plain'; break; case 'php': $mimetype = 'text/plain'; break; case 'css': $mimetype = 'text/css'; break; case 'jpg': $mimetype = 'image/jpeg'; break; case 'jpeg': $mimetype = 'image/jpeg'; break; case 'jpe': $mimetype = 'image/jpeg'; break; case 'gif': $mimetype = 'image/gif'; break; case 'png': $mimetype = 'image/png'; break; default: $mimetype = 'application/octet-stream'; break; } return $mimetype; } } ?>
備注:這種方式的缺點是不支持批量生成和下載,因為一個頁面只能有一個,(無論是遠(yuǎn)程使用還是本地生成的聲明頁面都只能輸出一個),即使你生成了在一個循環(huán)中,結(jié)果仍然只有一個字(當(dāng)然你可以修改上面的方式來實現(xiàn))
2.純HTML格式寫字
原則:
先用來存儲html頁面(解決頁面上的多個問題,可以批量生成),然后在寫入doc文檔內(nèi)容時使用
代碼:
'; } function save($path) { echo "