欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

pHp生成word的三種實(shí)現(xiàn)方式,利用php將內(nèi)容寫入Word

2023-12-02    分類: 網(wǎng)站建設(shè)

實(shí)現(xiàn)pHp生成word文檔的三種方法

更新時(shí)間:2016年11月14日14:13:09 作者:pHp淮北

本文主要介紹pHp生成word的三種實(shí)現(xiàn)方法。使用 pHp 將內(nèi)容寫入 Word。如果需要,可以了解一下。

最近在工作中遇到了生詞問題

現(xiàn)在總結(jié)一下生成詞的三種方法。

btw:只要標(biāo)題有pHp,好像點(diǎn)擊量不是很高(兄弟,我標(biāo)題里還有pHp),不知道為什么,估計(jì)是網(wǎng)多了博客園的技術(shù)專家。如果你用java、.net、php就像程序員的女朋友,那么java就是家底最好的姑娘,.net微軟底下的名門,pHp就是草根下的狂野阿姨。這讓我等著pHp草民們?nèi)コ惺苓@份情意。 投訴完了,正式寫起來

pHp生成詞的原理

具體實(shí)現(xiàn):

使用下面的com組件

原理:com是pHp的擴(kuò)展。安裝好的服務(wù)器會(huì)自動(dòng)調(diào)用word。 com,可以自動(dòng)生成文檔。 pHp官方文檔手冊(cè):

使用官方示例:

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;
?>

個(gè)人建議:com實(shí)例后面的所有方法都需要查官方文檔才知道是什么意思。編輯器沒有代碼提示,非常不方便。另外這個(gè)效率不是很高,所以不推薦。

使用 pHp 將內(nèi)容寫入 doc 文件

這個(gè)方法可以分為兩種方法。

生成mht格式(類似HTML)并寫字

/**
 * 根據(jù)HTML代碼獲取word文檔內(nèi)容
 * 創(chuàng)建一個(gè)本質(zhì)為mht的文檔,該函數(shù)會(huì)分析文件內(nèi)容并從遠(yuǎn)程下載頁面中的圖片資源
 * 該函數(shù)依賴于類MhtFileMaker
 * 該函數(shù)會(huì)分析img標(biāo)簽,提取src的屬性值。但是,src的屬性值必須被引號(hào)包圍,否則不能提取
 * 
 * @param string $content HTML內(nèi)容
 * @param string $absolutepath 網(wǎng)頁的絕對(duì)路徑。如果HTML內(nèi)容里的圖片路徑為相對(duì)路徑,那么就需要填寫這個(gè)參數(shù),來讓該函數(shù)自動(dòng)填補(bǔ)成絕對(duì)路徑。這個(gè)參數(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();
 //這個(gè)算法要求src后的屬性值必須使用引號(hào)括起來
 if ( preg_match_all('//i',$content ,$matches ) )
 {
  $arrpath = $matches[1];
  for ( $i=0;$iAddContents("tmp.html",$mht->GetMimeType("tmp.html"),$content);
  
 for ( $i=0;$iAddContents($files[$i],$mht->GetMimeType($image),$imgcontent);
  }
  else
  {
   echo "file:".$image." not exist!
"; } } return $mht->GetFile(); }

這個(gè)函數(shù)的主要作用其實(shí)就是分析HTML代碼中的所有圖片地址,依次下載。獲取到圖片內(nèi)容后php導(dǎo)出word格式數(shù)據(jù)的實(shí)現(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代碼中填寫圖片相對(duì)路徑的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;

注意在使用這個(gè)函數(shù)之前php導(dǎo)出word格式數(shù)據(jù)的實(shí)現(xiàn)代碼,需要先包含這個(gè)類,這個(gè)類可以幫助我們生成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;
 }
}
?>

備注:這種方式的缺點(diǎn)是不支持批量生成和下載,因?yàn)橐粋€(gè)頁面只能有一個(gè),(無論是遠(yuǎn)程使用還是本地生成的聲明頁面都只能輸出一個(gè)),即使你生成了在一個(gè)循環(huán)中,結(jié)果仍然只有一個(gè)字(當(dāng)然你可以修改上面的方式來實(shí)現(xiàn))

2.純HTML格式寫字

原則:

先用來存儲(chǔ)html頁面(解決頁面上的多個(gè)問題,可以批量生成),然后在寫入doc文檔內(nèi)容時(shí)使用

代碼:

';
}
function save($path)
{
 
echo "";
$data = ob_get_contents();
ob_end_clean();
 
$this->wirtefile ($path,$data);
}
 
function wirtefile ($fn,$data)
{
$fp=fopen($fn,"wb");
fwrite($fp,$data);
fclose($fp);
}
}

$html = ' 
pHp10086 http://www.php10086.com
pHp10086 http://www.php10086.com
pHp10086
最靠譜的pHp技術(shù)博客分享網(wǎng)站
'; //批量生成 for($i=1;$i<=3;$i++){ $word = new word(); $word->start(); //$html = "aaa".$i; $wordname = 'pHp淮北的個(gè)人網(wǎng)站--pHp10086.com'.$i.".doc"; echo $html; $word->save($wordname); ob_flush();//每次執(zhí)行前刷新緩存 flush(); }

個(gè)人評(píng)論:此方法最有效的原因有兩個(gè):

第一個(gè)代碼比較簡潔易懂,第二個(gè)支持批量生成單詞(這個(gè)很重要)

第三次支持完整的html代碼

生成三個(gè)word文檔:并且內(nèi)容支持完整的html代碼展示,強(qiáng)烈推薦第三種方法

以上是本文的全部內(nèi)容。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持。

新聞標(biāo)題:pHp生成word的三種實(shí)現(xiàn)方式,利用php將內(nèi)容寫入Word
文章轉(zhuǎn)載:http://aaarwkj.com/news10/298110.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供面包屑導(dǎo)航、外貿(mào)網(wǎng)站建設(shè)外貿(mào)建站、App設(shè)計(jì)品牌網(wǎng)站建設(shè)、定制開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

營銷型網(wǎng)站建設(shè)
国产成人在线观看av| 亚洲av成人一区二区三区| 成年人黄色免费网站在线观看| 草草在线成年免费视频| 大胸妇女引诱老师在线观看| 日本一区二区视频播放网站| 亚洲一区二区日本乱码| 日本在线视频精品一区| 亚洲精品一区二区三区三州| 亚洲精品一区二区免费看| 亚洲精品福利一二三区| 色橹橹欧美午夜精品福利| 亚洲国产一区二区高清| 亚洲女优中文字幕在线免费| 日韩一级不卡高清视频| 国产精品中文第一字幕| 中文字幕免费不卡一区| 国精品午夜福利视频不卡| 午夜情色视频在线观看| 免费又色又爽无遮挡网站| 亚洲第一女人天堂av| 丝袜亚洲激情欧美日韩偷拍 | 久久久久久亚洲精品少妇| 九七青青草视频在线观看| 一区二区三区欧美日韩| 精品亚洲韩国一区二区三区| 蜜桃精品国产一区二区三区 | 欧美亚洲av一区二区三区| 成年黄网站免费视频大全| 欧美日本国产在线一区二区| 精品日韩欧美精品日韩| 91精品国产成人在线| 欧美日韩免费爱爱视频| av中文资源在线观看| 中文字幕精品一区二区三区在线| 国产三级传媒在线观看| 成人激情视频在线网页| 亚洲女人淫片在线观看| 亚洲欧洲日韩另类在线| 激情综合婷婷中文字幕| 欧美黄色免费电影网站|