この記事では、主に php を介して Excel に HTML コンテンツ ファイルをエクスポートする方法を説明します。お役に立てれば幸いです。
<?php /** * 导出Excel(内容为HTML)文件类 * @author yzq */ class Excel_html{ private $_common_style = ''; //通用样式 private $_head = ''; //表头内容 private $_body = ''; //表格内容 private $_head_bgcolor = '#f3f3f3'; //表头默认背景颜色 private $_body_bgcolor = ''; //表格默认背景颜色 private $_default_width = 100; //默认宽度 Private $_default_align = 'center'; //默认对齐方式 private $_default_charset = 'utf-8'; //默认导出编码 private $_tables = []; //一个文件里有多个table时使用 private $_table_brs = []; //table间是否换行 /** * 设置表头背景颜色 */ public function set_head_bgcolor($bgcolor = '#f3f3f3'){ $this->_head_bgcolor = $bgcolor; } /** * 设置表格背景颜色 */ public function set_body_bgcolor($bgcolor = ''){ $this->_body_bgcolor = $bgcolor; } /** * 设置输出字符编码 */ public function set_charset($charset = 'utf-8'){ $this->_default_charset = $charset; } /** * 设置默认对齐方式 */ public function set_align($align = 'center'){ $this->_default_align = $align; } /** * 设置默认宽度 * @param int $width */ public function set_default_width($width = 100){ $this->_default_width = $width; } /** * 设置通用样式 * @param string $style */ public function set_common_style($style = ''){ $this->_common_style = $style; } /** * 添加一个table * @param int $add_br 是否添加换行 */ public function add_talbe($add_br = 0){ $this->_tables[] = array( 'head' => $this->_head, 'body' => $this->_body, ); $this->_table_brs[] = $add_br ? 1 : 0; $this->_head = ''; $this->_body = ''; } /** * 添加表头 * @param array $head_arr = array( * // array(array(字段名1, 宽度, 其他设置), 字段名2) 宽度 其他设置(如跨列,跨行等) 可选 * array( * array('序号', 100, ['colspan' => 2, 'rowspan' => 2]), * '订单号', * '同行客户' * ) * ) * */ public function add_head($head_arr = array()){ $head_html = '<tr>'; if (is_array($head_arr) && !empty($head_arr)){ foreach ($head_arr as $head){ if (!is_array($head)){ $head_html .= "<th width='" . $this->_default_width . "' bgcolor='" . $this->_head_bgcolor . "'>" . $this->get_value($head) . "</th>\n"; }else { $width = !empty($head[1]) ? $head[1] : $this->_default_width; $other = isset($head[2]) ? $head[2] : []; $head_html .= "<th width='" . $width . "' bgcolor='" . $this->_head_bgcolor . "'"; if(!empty($other) && is_array($other)){ foreach($other as $k => $v){ $head_html .= " {$k}='{$v}' "; } } $head_html .= " >" . $this->get_value($head[0]) . "</th>\n"; } } } $head_html .= "</tr>\n"; $this->_head .= $head_html; } /** * 添加表格内容 * @param array $body_arr = array( * //array(array(字段值, 对齐方式, 样式, 其他设置)) //对齐方式、样式、其他设置(如跨列,跨行等)可选 * array( * array(1, 'left', 'style="..."', ['colspan' => 2, 'rowspan' => 2]), * array('2', 'right'), * 3 * ) * ) * * @param $deal_long_num 是否处理长度较长的数字字符串 防止转换为科学计数法 * */ public function add_body($body_arr = array(), $deal_long_num = false){ $body_html = '<tr>'; if (is_array($body_arr) && !empty($body_arr)){ foreach ($body_arr as $body){ if (!is_array($body)){ $style = $deal_long_num ? 'style="mso-number-format:\'\@\';"' : ''; $body_html .= "<td bgcolor='" . $this->_body_bgcolor . "' align='" . $this->_default_align . "' {$style}>" . $this->get_value($body) . "</td>\n"; }else { $align = isset($body[1]) ? $body[1] : $this->_default_align; $style = isset($body[2]) ? $body[2] : ''; $other = isset($body[3]) ? $body[3] : []; if (!empty($style)){ $style = $deal_long_num ? (rtrim($style, ';"') . ";mso-number-format:'\@';" . '"') : $style; }else{ $style = $deal_long_num ? 'style="mso-number-format:\'\@\';"' : ''; } $body_html .= "<td bgcolor='" . $this->_body_bgcolor . "' align='" . $align ."' " . $style . ""; if(!empty($other) && is_array($other)){ foreach($other as $k => $v){ $body_html .= " {$k}='{$v}' "; } } $body_html .= ">" . $this->get_value($body[0]) . "</td>\n"; } } } $body_html .= "</tr>\n"; $this->_body .= $body_html; } /** * 下载excel文件 */ public function downLoad($filename = ''){ $this->add_talbe(); $chare_set = $this->_default_charset; $down_content = '<meta http-equiv="Content-Type" content="text/html; charset=' . $chare_set . '" />' . "\n"; $down_content .= $this->_common_style; foreach ($this->_tables as $t_key => $table){ if (empty($table['head']) && empty($table['body'])){ continue; } $down_content .= '<table border="1">' . "\n"; $down_content .= $table['head'] . "\n"; $down_content .= $table['body'] . "\n"; $down_content .= '</table>'; if ($this->_table_brs[$t_key]){ $down_content .= "<br/>"; } $down_content .= "\n"; } if(!$filename) { $filename = date('YmdHis',time()).'.xls'; } $ci = &get_instance(); $ci->load->helper('download'); force_download($filename, $down_content); } private function get_value($value){ if (strtolower($this->_default_charset) != 'utf-8'){ return iconv('utf-8', $this->_default_charset, $value); }else{ return $value; } } }
使用例:
$excel = new Excel_html(); $head = [ ['序号', 50], ['姓名', 100], ['移动电话', 120], ['部门', 120] ]; $excel->add_head($head); $rs = array( array( 'realname' => 'a', 'mobile' => '12345678901', 'department_name' => '测试', ), array( 'realname' => 'b', 'mobile' => '12345678912', 'department_name' => '技术', ), ); foreach($rs as $i => $item){ $excel->add_body([ $i + 1, $item['realname'], $item['mobile'], $item['department_name'], ]); } $excel->downLoad(); exit();
関連推奨事項:
php ネイティブ メソッドを使用して Excel インスタンス共有をエクスポート
以上がExcel での PHP エクスポート HTML コンテンツ ファイル クラス メソッドの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

本篇文章给大家带来了关于excel的相关知识,其中主要介绍了关于折叠表格的相关问题,就是分类汇总的功能,这样查看数据会非常的方便,下面一起来看一下,希望对大家有帮助。

在之前的文章《实用Excel技巧分享:利用 数据透视表 来汇总业绩》中,我们学习了下Excel数据透视表,了解了利用数据透视表来汇总业绩的方法。而今天我们来聊聊怎么计算时间差(年数差、月数差、周数差),希望对大家有所帮助!

本篇文章给大家带来了关于excel的相关知识,其中主要介绍了关于AGGREGATE函数的相关内容,该函数用法与SUBTOTAL函数类似,但在功能上比SUBTOTAL函数更加强大,下面一起来看一下,希望对大家有帮助。

在之前的文章《实用Word技巧分享:聊聊你没用过的“行号”功能》中,我们了解了Word中你肯定没用过的"行号”功能。今天继续实用Word技巧分享,看看Excel表格怎么借用Word进行分栏打印,快来收藏使用吧!

在之前的文章《实用Excel技巧分享:原来“定位功能”这么有用!》中,我们了解了定位功能的妙用。而今天我们聊聊合并后的单元格如何实现筛选功能,分享一种复制粘贴和方法解决这个问题,另外还会给大家分享一种合并单元格的不错的替代方式。

本篇文章给大家带来了关于excel的相关知识,其中主要介绍了关于zenmm制作倒计时牌的相关内容,使用Excel中的日期函数结合按指定时间刷新的VBA代码,即可制作出倒计时牌,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于excel的相关知识,其中主要介绍了关于如何使用函数寻找总和为某个值的组合的问题,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于excel的相关知识,其中主要介绍了关于折线图的相关问题,下面就根据一些示例来看一下怎么去应用,希望对大家有帮助。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

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

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

SecLists
SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境
