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

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



Alipay PHP ...

JWT ist ein offener Standard, der auf JSON basiert und zur sicheren Übertragung von Informationen zwischen Parteien verwendet wird, hauptsächlich für die Identitätsauthentifizierung und den Informationsaustausch. 1. JWT besteht aus drei Teilen: Header, Nutzlast und Signatur. 2. Das Arbeitsprinzip von JWT enthält drei Schritte: Generierung von JWT, Überprüfung von JWT und Parsingnayload. 3. Bei Verwendung von JWT zur Authentifizierung in PHP kann JWT generiert und überprüft werden, und die Funktionen und Berechtigungsinformationen der Benutzer können in die erweiterte Verwendung aufgenommen werden. 4. Häufige Fehler sind Signaturüberprüfungsfehler, Token -Ablauf und übergroße Nutzlast. Zu Debugging -Fähigkeiten gehört die Verwendung von Debugging -Tools und Protokollierung. 5. Leistungsoptimierung und Best Practices umfassen die Verwendung geeigneter Signaturalgorithmen, das Einstellen von Gültigkeitsperioden angemessen.

Die Anwendung des soliden Prinzips in der PHP -Entwicklung umfasst: 1. Prinzip der Einzelverantwortung (SRP): Jede Klasse ist nur für eine Funktion verantwortlich. 2. Open and Close Principle (OCP): Änderungen werden eher durch Erweiterung als durch Modifikation erreicht. 3.. Lischs Substitutionsprinzip (LSP): Unterklassen können Basisklassen ersetzen, ohne die Programmgenauigkeit zu beeinträchtigen. 4. Schnittstellen-Isolationsprinzip (ISP): Verwenden Sie feinkörnige Schnittstellen, um Abhängigkeiten und nicht verwendete Methoden zu vermeiden. 5. Abhängigkeitsinversionsprinzip (DIP): Hoch- und niedrige Module beruhen auf der Abstraktion und werden durch Abhängigkeitsinjektion implementiert.

In Artikel wird die in PHP 5.3 eingeführte LSB -Bindung (LSB) erörtert, die die Laufzeitauflösung der statischen Methode ermöglicht, um eine flexiblere Vererbung zu erfordern. Die praktischen Anwendungen und potenziellen Perfo von LSB

Senden von JSON -Daten mithilfe der Curl -Bibliothek von PHP in der PHP -Entwicklung müssen häufig mit externen APIs interagieren. Eine der gängigen Möglichkeiten besteht darin, die Curl Library zu verwenden, um Post � ...

In Artikel werden wichtige Sicherheitsfunktionen in Frameworks erörtert, um vor Schwachstellen zu schützen, einschließlich Eingabevalidierung, Authentifizierung und regelmäßigen Aktualisierungen.

So setzen Sie die Berechtigungen von Unixsocket automatisch nach dem Neustart des Systems. Jedes Mal, wenn das System neu startet, müssen wir den folgenden Befehl ausführen, um die Berechtigungen von Unixsocket: sudo ...

In dem Artikel werden Frameworks hinzugefügt, das sich auf das Verständnis der Architektur, das Identifizieren von Erweiterungspunkten und Best Practices für die Integration und Debuggierung hinzufügen.
