久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

excel的導出和下載(實例講解)

下面小編就為大家帶來一篇excel的導出和下載(實例講解)。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

1、前言

有時需要將數據庫表資源導出excel,做成一些報表數據。

而php導出excel的方法大致有幾種:

1. 使用php的類庫,進行導出,如PHPExcel

2.使用php原生的方法進行導出

而本文介紹的就是,如何通過原生方法導出excel

2、關鍵函數

2.1、ob輸出

•ob_start();
•ob_get_contents
•ob_end_clean
•fopen
•fwrite
•fclose
•iconv

2.2、header輸出

1.header
2.iconv

3、使用ob函數進行excel到導出

ob函數主要分為三步:

1.進行緩存的設置
2.讀取緩存
3.寫入文件

下面貼上導出的excel類

<?php
class Excel 
{
 // ob函數緩存的開始
 public static function start ()
 {
  ob_start();
 }
 // 獲取緩存內容
 public static function save ($path) 
 {
  $data = ob_get_contents();
  ob_end_clean();
  self::writeToExcel($path, $data);
 }
 //寫到文件
 private static function writeToExcel ($fn, $data) 
 {
  $dir = self::setDir();
  $fp = fopen($dir . '/'. $fn, 'wb');
  fwrite($fp, $data);
  fclose($fp);
 }
 //excel默認是GKB,所有要轉碼
 public static function setChar ($value, $inchar = 'utf-8', $outchar ='gbk')
 {
  return iconv($inchar, $outchar, $value);//轉化編碼
 }
 //創建目錄,linux系統一般要寫到文件,目錄需要w謙虛,而文件需要x權限,為了省事直接建立子文件夾,可以不需要修改謙虛
 public static function setDir($dirName = 'excel')
 {
  if(!is_dir($dirName)) {
   mkdir($dirName);
  }
  return $dirName;
 }
}

4、完整頁面代碼

<?php
 header('Content-Type: text/html; charset=GBK'); //excel需要GBK編碼,為了防止轉碼產生的亂碼,需要設置成GBK
 require 'coon.php';
 require 'excel.class.php';

 $sql = 'select * from user';
 $res = $link->query($sql);
 //判斷是否有發送get數據
 if(isset($_GET['id'])){
  $name = empty($_GET['id']) ? 'a' . rand(1000,9999) : $_GET['id'] ;
  $filename = $name . '.xls';
  //設置緩存的開始
  Excel::start();
 }
?>
<?php
 //頁面輸出一般是不需要轉碼的,excel輸出才需要轉碼
 echo '<table width=500 height=25 border=0 align=center cellpadding=0 cellspacing=0>';
 echo '<thead><tr>';
 //設置thead輸出
 echo '<td style="border-bottom:1px solid black;padding:10px;text-align:center;">' . Excel::setChar('編號') . '</td>';
 echo '<td style="border-bottom:1px solid black;padding:10px;text-align:center;">' . Excel::setChar('用戶名') . '</td>';
 echo '<td style="border-bottom:1px solid black;padding:10px;text-align:center;">' . Excel::setChar('密碼') . '</td>';
 echo '</thead></tr>';
?>
<?php
 echo '<tbody>';
 //設置tbody輸出
 while($re = $res->fetch(PDO::FETCH_ASSOC)){
  echo '<tr>';
  echo '<td style="border-bottom:1px solid black;padding:10px;text-align:center;">' . Excel::setChar($re['id']) . '</td>';
  echo '<td style="border-bottom:1px solid black;padding:10px;text-align:center;">' . Excel::setChar($re['user']) . '</td>';
  echo '<td style="border-bottom:1px solid black;padding:10px;text-align:center;">' . Excel::setChar($re['pwd']) . '</td>';
  echo '</tr>';
 }
 echo '</tbody></table>';
?>
<?php
if(isset($_GET['id'])){
 //保存文件
 Excel::save($filename);
}
if(isset($_GET['id'])){
 echo '<a href="obexcel.php" rel="external nofollow" >' .Excel::setChar('完成') .'</a>';
}else{
 echo '<a href="obexcel.php?id" rel="external nofollow" >' . Excel::setChar('導出') .'</a>';
 
}
?>

5、使用header下載excel

使用ob函數導出excel只能保存到服務器,不能提供下載(特殊處理下還是可以的);下面介紹使用header()函數來導出并下載excel

主要兩個header()函數

header("Content-type:application/vnd.ms-excel");//指定文件類型 
header("Content-Disposition:filename=a.xls" ); //指定下載文件名

其他做法和ob函數的導出相同(下面完整代碼)

<?php

//下載主要靠這兩個
header("Content-type:application/vnd.ms-excel");//指定文件類型 
header("Content-Disposition:filename=a.xls" ); //指定下載文件名
require 'coon.php';
require 'excel.class.php';
$sql = 'select * from user';
$res = $link->query($sql);
?>

<?php
 //頁面輸出一般是不需要轉碼的,excel輸出才需要轉碼
 echo '<table width=500 height=25 border=0 align=center cellpadding=0 cellspacing=0>';
 echo '<thead><tr>';
 //設置thead輸出
 echo '<td style="border-bottom:1px solid black;padding:10px;text-align:center;">' . Excel::setChar('編號') . '</td>';
 echo '<td style="border-bottom:1px solid black;padding:10px;text-align:center;">' . Excel::setChar('用戶名') . '</td>';
 echo '<td style="border-bottom:1px solid black;padding:10px;text-align:center;">' . Excel::setChar('密碼') . '</td>';
 echo '</thead></tr>';
?>

<?php
 echo '<tbody>';
 //設置tbody輸出
 while($re = $res->fetch(PDO::FETCH_ASSOC)){
  echo '<tr>';
  echo '<td style="border-bottom:1px solid black;padding:10px;text-align:center;">' . Excel::setChar($re['id']) . '</td>';
  echo '<td style="border-bottom:1px solid black;padding:10px;text-align:center;">' . Excel::setChar($re['user']) . '</td>';
  echo '<td style="border-bottom:1px solid black;padding:10px;text-align:center;">' . Excel::setChar($re['pwd']) . '</td>';
  echo '</tr>';
 }
 echo '</tbody></table>';
?>

6、結語

【網站聲明】本站除付費源碼經過測試外,其他素材未做測試,不保證完整性,網站上部分源碼僅限學習交流,請勿用于商業用途。如損害你的權益請聯系客服QQ:2655101040 給予處理,謝謝支持。

相關文檔推薦

主站蜘蛛池模板: 久久成人综合 | 亚洲精品一区二区 | 国产精品久久久 | 日韩一区二区三区在线观看视频 | 亚洲一区日韩 | 黄色片视频 | av福利网站 | 亚洲成人一区 | 超碰520| 久久久久国产一区二区三区 | 91精品久久久久 | 国产精品久久久久久 | 久久久精品在线 | 欧美精品1区2区3区 精品国产欧美一区二区 | 久久久久一区 | 久久国产麻豆 | 精品国产乱码久久久久久闺蜜 | 日韩精品视频在线免费观看 | 日韩三区 | 国产精品亚洲一区二区三区在线观看 | 成人午夜在线视频 | 日韩亚洲欧美综合 | 国内av在线 | 国产精品亚洲精品久久 | 99视频免费看 | 蜜月aⅴ免费一区二区三区 99re在线视频 | 在线观看涩涩视频 | 91精品国产91久久久久福利 | 蜜臀久久99精品久久久久久宅男 | 欧美日韩在线观看视频 | 本地毛片 | 男人的天堂在线视频 | 欧美成人免费电影 | aaa综合国产| 国产精品视频免费观看 | 久久成人18免费网站 | 国产精品久久av | 黑人精品| 国产高清一二三区 | 中文字幕第一页在线 | www.久久.com |