ホームページ php教程 php手册 thinkphp3.2.3结合PHPExcel导出数据库里所有表的结构

thinkphp3.2.3结合PHPExcel导出数据库里所有表的结构

Jun 07, 2016 am 11:39 AM

前面已经做过了一个关于这方面的demo,但没有对excel进行格式设置,用户体验不友好,这次做了改正,希望在项目开发的时候,大家能用得上.
按惯例,先上图
thinkphp3.2.3结合PHPExcel导出数据库里所有表的结构

代码如下:  public function out(){    <br>         //读取库里所有的表            <br>         $sql="show tables";   <br>         $result=M()->query($sql);  <br>         foreach ($result as $k=>$v) {             <br>             $k++;                     <br>             $_sql="SHOW FULL COLUMNS FROM ".$v['tables_in_'.C('DB_NAME')]; <br>             $data[][0]=array("表 {$k}.".$v['tables_in_'.C('DB_NAME')]."表",'','','','','','');<br>             $data[][1]=array("字段","类型","校对","NULL","键","默认","额外","权限","注释");<br>             $data[]=M()->query($_sql);  <br> <br>             $data[][]=array();                      <br>         }          <br>         //导入PHPExcel类库         <br>         import("Common.Org.PHPExcel");        <br>         import("Common.Org.PHPExcel.Writer.Excel5");         <br>         import("Common.Org.PHPExcel.IOFactory.php");         <br>         $filename="test_excel";              <br>         $this->getExcel($filename,$data);    <br>     }  <br> <br>     private function getExcel($fileName,$data){             <br>     //对数据进行检验            <br>          if(empty($data)||!is_array($data)){                 <br>              die("data must be a array");             <br>          }             <br>         $date=date("Y_m_d",time()); <br>         $fileName.="_{$date}.xls";              <br>         //创建PHPExcel对象,注意,不能少了\             <br>         $objPHPExcel=new \PHPExcel();             <br>         $objProps=$objPHPExcel->getProperties();  <br> <br>         $column=2;             <br>         $objActSheet=$objPHPExcel->getActiveSheet();   <br>         $objPHPExcel->getActiveSheet()->getStyle()->getFont()->setName('微软雅黑');//设置字体<br>         $objPHPExcel->getActiveSheet()->getDefaultRowDimension()->setRowHeight(25);//设置默认高度<br> <br>         $objPHPExcel->getActiveSheet()->getColumnDimension('A')->setWidth('5');//设置列宽<br>         $objPHPExcel->getActiveSheet()->getColumnDimension('B')->setWidth('22');//设置列宽<br>         $objPHPExcel->getActiveSheet()->getColumnDimension('C')->setWidth('22');//设置列宽<br>         $objPHPExcel->getActiveSheet()->getColumnDimension('J')->setWidth('40');//设置列宽<br> <br>         //设置边框<br>         $sharedStyle1=new \PHPExcel_Style();<br>         $sharedStyle1->applyFromArray(array('borders'=>array('allborders'=>array('style'=>\PHPExcel_Style_Border::BORDER_THIN))));<br>         <br>         foreach ($data as $ke=>$row){      <br> <br>             foreach($row as $key=>$rows){<br> <br>                 if(count($row)==1&&empty($row[0][1])&&empty($rows[1])&&!empty($rows)){<br> <br>                     $objPHPExcel->getActiveSheet()->setSharedStyle($sharedStyle1, "A{$column}:J{$column}");//设置边框<br>                     array_unshift($rows,$rows['0']);<br>                     $objPHPExcel->getActiveSheet()->mergeCells("A{$column}:J{$column}");//合并单元格<br>                     $objPHPExcel->getActiveSheet()->getStyle("A{$column}:J{$column}")->getFont()->setSize(12);//字体<br>                     $objPHPExcel->getActiveSheet()->getStyle("A{$column}:J{$column}")->getFont()->setBold(true);//粗体<br> <br>                     //背景色填充<br>                     $objPHPExcel->getActiveSheet()->getStyle("A{$column}:J{$column}")->getFill()->setFillType(\PHPExcel_Style_Fill::FILL_SOLID);<br>                     $objPHPExcel->getActiveSheet()->getStyle("A{$column}:J{$column}")->getFill()->getStartColor()->setARGB('FFB8CCE4');<br> <br>                 }else{<br>                     if(!empty($rows)){<br>                         array_unshift($rows,$key+1);<br>                         $objPHPExcel->getActiveSheet()->setSharedStyle($sharedStyle1,"A{$column}:J{$column}");//设置边框<br>                     } <br>                 }<br> <br>                 if($rows['1']=='字段'){<br>                     $rows[0]='ID';<br>                     //背景色填充<br>                     $objPHPExcel->getActiveSheet()->getStyle("A{$column}:J{$column}")->getFill()->setFillType(\PHPExcel_Style_Fill::FILL_SOLID);<br>                     $objPHPExcel->getActiveSheet()->getStyle("A{$column}:J{$column}")->getFill()->getStartColor()->setARGB('FF4F81BD');<br>                 }<br> <br>                 $objPHPExcel->getActiveSheet()->getStyle("A{$column}:J{$column}")->getAlignment()->setVertical(\PHPExcel_Style_Alignment::VERTICAL_CENTER);//垂直居中<br>                 $objPHPExcel->getActiveSheet()->getStyle("A{$column}:J{$column}")->getAlignment()->setWrapText(true);//换行<br>                  //行写入                     <br>                 $span = ord("A");                       <br>                 foreach($rows as $keyName=>$value){                    <br>                     // 列写入                       <br>                     $j=chr($span);                         <br>                     $objActSheet->setCellValue($j.$column, $value);                        <br>                     $span++;                     <br>                 }                     <br>                 $column++;                 <br>             }             <br>         } <br>         $fileName = iconv("utf-8", "gb2312", $fileName);             <br>         //设置活动单指数到第一个表,所以Excel打开这是第一个表             <br>         $objPHPExcel->setActiveSheetIndex(0);             <br>         header('Content-Type: application/vnd.ms-excel');             <br>         header("Content-Disposition: attachment;filename=\"$fileName\"");             <br>         header('Cache-Control: max-age=0');                <br>         $objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');             <br>         $objWriter->save('php://output'); //文件通过浏览器下载             <br>         exit;     <br>     }PHPExcel插件放在应用目录下的Common模块下的Org文件夹里,附带附件,大家可以下载,大家也可以改进,希望能把改进后的分享出来!

附件 tp323-PHPExcel.zip ( 1.91 MB 下载:711 次 )

AD:真正免费,域名+虚机+企业邮箱=0元

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

Python プログラミングの入門コード例について学びます。 Python プログラミングの入門コード例について学びます。 Jan 04, 2024 am 10:50 AM

入門コード例で Python プログラミングについて学ぶ Python は、習得が簡単でありながら強力なプログラミング言語です。初心者にとって、Python プログラミングの入門コード例を理解することは非常に重要です。この記事では、すぐに始めるのに役立つ具体的なコード例をいくつか紹介します。 Print HelloWorldprint("HelloWorld") これは、Python の最も単純なコード例です。 print()関数は、指定された内容を出力するために使用されます。

PHP 変数の実際の使用: 10 の実際の使用例 PHP 変数の実際の使用: 10 の実際の使用例 Feb 19, 2024 pm 03:00 PM

PHP 変数はプログラムの実行中に値を保存し、動的でインタラクティブな WEB アプリケーションを構築するために重要です。この記事では、PHP 変数を詳しく説明し、10 個の実際の例を使用して実際に動作する様子を示します。 1. ユーザー入力の保存 $username=$_POST["username"];$passWord=$_POST["password"]; この例では、フォーム送信からユーザー名とパスワードを抽出し、その後の処理のために変数に保存します。 2. 構成値 $database_host="localhost";$database_username="username";$database_pa を設定します。

Go 言語プログラミングの例: Web 開発のコード例 Go 言語プログラミングの例: Web 開発のコード例 Mar 04, 2024 pm 04:54 PM

「Go 言語プログラミングの例: Web 開発におけるコード例」 インターネットの急速な発展に伴い、Web 開発はさまざまな業界で不可欠な部分になりました。 Go 言語は、強力な機能と優れたパフォーマンスを備えたプログラミング言語として、Web 開発の開発者にますます好まれています。この記事では、読者が Go 言語をより深く理解し、Go 言語を使用して独自の Web アプリケーションを構築できるように、具体的なコード例を通じて Web 開発に Go 言語を使用する方法を紹介します。 1. シンプルな HTTP サーバー まず、

初心者から熟練者まで: Go 言語で一般的に使用されるデータ構造のコード実装 初心者から熟練者まで: Go 言語で一般的に使用されるデータ構造のコード実装 Mar 04, 2024 pm 03:09 PM

タイトル: 初心者から熟練者まで: Go 言語で一般的に使用されるデータ構造のコード実装 データ構造はプログラミングにおいて重要な役割を果たし、プログラミングの基礎です。 Go 言語には、一般的に使用されるデータ構造が多数あり、これらのデータ構造の実装をマスターすることは、優れたプログラマーになるために重要です。この記事では、Go 言語で一般的に使用されるデータ構造を紹介し、読者がこれらのデータ構造を使い始めて習熟するのに役立つ、対応するコード例を示します。 1. 配列 配列は基本的なデータ構造であり、同じ型のグループです。

Java は単純なバブルソートコードを実装します Java は単純なバブルソートコードを実装します Jan 30, 2024 am 09:34 AM

Java バブル ソートの最も簡単なコード例 バブル ソートは一般的な並べ替えアルゴリズムであり、その基本的な考え方は、並べ替える順序を、隣接する要素の比較と交換を通じて順序付けされた順序に徐々に調整することです。次に、バブル ソートの実装方法を示す簡単な Java コード例を示します。 publicclassBubbleSort{publicstaticvoidbubbleSort(int[]arr){int

Huawei Cloud Edge Computing Interconnection Guide: インターフェースを迅速に実装するための Java コード例 Huawei Cloud Edge Computing Interconnection Guide: インターフェースを迅速に実装するための Java コード例 Jul 05, 2023 pm 09:57 PM

Huawei クラウド エッジ コンピューティング相互接続ガイド: インターフェイスを迅速に実装するための Java コード サンプル IoT テクノロジーの急速な発展とエッジ コンピューティングの台頭により、ますます多くの企業がエッジ コンピューティングのアプリケーションに注目し始めています。 Huawei Cloud はエッジ コンピューティング サービスを提供し、企業に信頼性の高いコンピューティング リソースと便利な開発環境を提供し、エッジ コンピューティング アプリケーションの実装を容易にします。この記事では、Java コードを通じて Huawei Cloud エッジ コンピューティング インターフェイスを迅速に実装する方法を紹介します。まずは開発環境を準備する必要があります。 Java Development Kit がインストールされていることを確認してください (

ガイダンスと例: Java で選択ソート アルゴリズムを実装する方法を学習します。 ガイダンスと例: Java で選択ソート アルゴリズムを実装する方法を学習します。 Feb 18, 2024 am 10:52 AM

Java 選択ソート方法のコード記述ガイドと例 選択ソートは、シンプルで直観的なソート アルゴリズムです。そのアイデアは、ソートされていない要素から毎回最小 (または最大) の要素を選択し、すべての要素がソートされるまで交換することです。この記事では、選択項目の並べ替えのためのコード作成ガイドを提供し、特定の Java サンプル コードを添付します。アルゴリズム原理 選択ソートの基本原理は、ソート対象の配列をソート済み部分とソートされていない部分の 2 つの部分に分割し、その都度、未ソート部分から最小 (または最大) の要素が選択され、ソート済み部分の最後に配置されます。上記を繰り返します

PHPを使用して在庫管理システムに在庫管理機能コードを記述する方法 PHPを使用して在庫管理システムに在庫管理機能コードを記述する方法 Aug 06, 2023 pm 04:49 PM

PHP を使用して在庫管理システムの在庫管理機能コードを記述する方法 在庫管理は多くの企業にとって不可欠な部分です。複数の倉庫を持つ企業にとって、在庫管理機能は特に重要です。在庫を適切に管理および追跡することで、企業は異なる倉庫間で在庫を割り当て、運用コストを最適化し、コラボレーション効率を向上させることができます。この記事では、PHP を使用して在庫倉庫管理機能のコードを記述する方法を紹介し、関連するコード例を示します。 1. 在庫倉庫管理機能のコードを書き始める前に、データベースを確立します。

See all articles