php数据转换为html table或者csv文件
应用场景:游戏中的很多业务已经迁移到了redis上,但是redis中的数据在运维层面很难展现,通过php-redis将redis中的set或者hash转换为php中的array,然后映射为html中的table
具体展现:
主要设计点:table的基本单位是单元格row_field_node,多个row_field_node组成row_data, tile + 多个row_data = table。因为每个单元格都可能有对应的超链接响应,
所以row_field_node数据结构是这样的:
class row_field_node{ public $data; //显示的数据 public $action; //对应的超链接 public $param; //超链接需要传入的参数 public $target; //超链接要展现在那个frame中 public function __construct($data, $action, $param, $target) { $this->data = $data; $this->action = $action; $this->param = $param; $this->target = $target; }}
array中的数组与hash可以输出为html table或者是csv文件,具体实现见代码:
<?phpheader ("Content-type: text/html; charset=utf-8");$domain_name = "192.168.1.1";class row_field_node{ public $data; public $action; public $param; public $target; public function __construct($data, $action, $param, $target) { $this->data = $data; $this->action = $action; $this->param = $param; $this->target = $target; }}class xtable{ private $title_list,$row_list,$fonts,$table_tag; public function __construct() { $this->title_list=array(); // strings with titles for first row $this->row_list=array(); // data to show on cells $this->fonts=array("#EEEEEE","#CCEEEE"); // background colors for odd and even rows $this->table_tag=""; // extra html code for table tag } public function set_table_tag($table_tag) // add some html code for the tag table { $this->table_tag=$table_tag; } public function background($fonts) { if (is_array($fonts)) { $this->fonts=$fonts; } else { $this->fonts=array($fonts,$fonts); } } public function addrow($row_data) { $this->row_list[]=$row_data; } public function hash_output($data) { $this->title_list=array("field", "value"); foreach($data as $key=> $value) { $row_data = array(); $field_data = new row_field_node($key, "", "", ""); array_push($row_data, $field_data); $field_data = new row_field_node($value, "", "", ""); array_push($row_data, $field_data); $this->addrow($row_data); } return $this->html(); } public function set_output($title, $data, $desc = '') { $this->title_list = $title; $this->row_list = $data; echo "total:".count($data).' '.$desc . "<br>"; return $this->html(); } public function html() { $cfondos=$this->fonts; //output title $output_content="<tr>"; $t_count=count($this->title_list); for($t_idx = 0; $t_idx %s",$this->title_list[$t_idx]); } $output_content.="</tr>"; //start outputing data rows $table_row_content=""; $row_count=count($this->row_list); for($row_idx = 0; $row_idx ", $this->fonts[$row_idx % 2]); $line_data_list = $this->row_list[$row_idx]; $col_count = count($line_data_list); if($col_count != $t_count) { echo "row field count not match title count|col:".$col_count."|title:".$t_count; exit; } for($col_idx = 0; $col_idx action != "") { //echo $line_data_list[$col_idx]->action."----".$line_data_list[$col_idx]->param."----".$line_data_list[$col_idx]->target."----".$line_data_list[$col_idx]->data."==============="; $table_row_content.=sprintf("<td align='\"center\"'><a href="%5C%22http://%24domain_name/%s?%s%5C%22" target="%s"> %s </a></td>", $line_data_list[$col_idx]->action, $line_data_list[$col_idx]->param, $line_data_list[$col_idx]->target, $line_data_list[$col_idx]->data); } else { $table_row_content.=sprintf("<td align='\"center\"'> %s </td>", $line_data_list[$col_idx]->data); } } $table_row_content.=""; } return sprintf("
"; return $this->csv(); } public function csv() { $file_name = time(0).".rar"; $fp = fopen($file_name, 'w'); $t_count=count($this->title_list); //start outputing data rows $row_count=count($this->row_list); $file_data = ""; $csv_row_data = ""; for($t_idx = 0; $t_idx title_list[$t_idx]; } $file_data = $file_data.$csv_row_data."\n"; for($row_idx = 0; $row_idx row_list[$row_idx]; $col_count = count($line_data_list); if($col_count != $t_count) { echo "row field count not match title count|col:".$col_count."|title:".$t_count; exit; } $csv_row_data = ""; for($col_idx = 0; $col_idx data; } $file_data = $file_data.$csv_row_data."\n"; } fwrite($fp, $file_data); Global $domain_name; echo "
csvfile:$file_name"; }}?>

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

JWT是一種基於JSON的開放標準,用於在各方之間安全地傳輸信息,主要用於身份驗證和信息交換。 1.JWT由Header、Payload和Signature三部分組成。 2.JWT的工作原理包括生成JWT、驗證JWT和解析Payload三個步驟。 3.在PHP中使用JWT進行身份驗證時,可以生成和驗證JWT,並在高級用法中包含用戶角色和權限信息。 4.常見錯誤包括簽名驗證失敗、令牌過期和Payload過大,調試技巧包括使用調試工具和日誌記錄。 5.性能優化和最佳實踐包括使用合適的簽名算法、合理設置有效期、

文章討論了PHP 5.3中介紹的PHP中的晚期靜態結合(LSB),允許靜態方法的運行時間分辨率調用以更靈活的繼承。 LSB的實用應用和潛在的觸摸

SOLID原則在PHP開發中的應用包括:1.單一職責原則(SRP):每個類只負責一個功能。 2.開閉原則(OCP):通過擴展而非修改實現變化。 3.里氏替換原則(LSP):子類可替換基類而不影響程序正確性。 4.接口隔離原則(ISP):使用細粒度接口避免依賴不使用的方法。 5.依賴倒置原則(DIP):高低層次模塊都依賴於抽象,通過依賴注入實現。

如何在系統重啟後自動設置unixsocket的權限每次系統重啟後,我們都需要執行以下命令來修改unixsocket的權限:sudo...

使用PHP的cURL庫發送JSON數據在PHP開發中,經常需要與外部API進行交互,其中一種常見的方式是使用cURL庫發送POST�...
