ArrayToTextTable
功能介紹
用于把數組數據轉為表格輸出。
相關Class位置
- ArrayToTextTable
-
namespace
:EasySwoole\Utility\ArrayToTextTable
-
核心對象方法
getTable
獲取表格
- mixed $data 表格數據
public function getTable($data = null)
setIndentation
設置表格縮進
- mixed $indentation 設置縮進
public function setIndentation($indentation)
isDisplayHeader
設置表格頭部
- bool $displayHeader 是否需要表格頭部
public function isDisplayHeader(bool $displayHeader)
setKeysAlignment
設置表格頭部對齊方式
- mixed $keysAlignment 表格頭部對齊方式
public function setKeysAlignment($keysAlignment)
setValuesAlignment
設置表格數據對齊方式
- mixed $keysAlignment 表格頭部對齊方式
public function setValuesAlignment($valuesAlignment)
setFormatter
處理表格數據格式
- mixed $formatter 數據方式
public function setFormatter($formatter)
基本使用
創建核心類的對象
$data = [
[
'name' => 'James',
'age' => '20',
'sex'=>'男'
],
[
'name' => 'Tony',
'age' => 50,
'email' => '291323003@qq.com',
],
];
//創建核心類的對象,并帶入了數據參數 $data
$renderer = new \EasySwoole\Utility\ArrayToTextTable($data);
//設置表格縮進
$renderer->setIndentation("\t");
//設置表格頭部
$renderer->isDisplayHeader(true);
//設置表格頭部對齊方式
$renderer->setKeysAlignment(\EasySwoole\Utility\ArrayToTextTable::AlignLeft);
//設置表格數據對齊方式
$renderer->setValuesAlignment(\EasySwoole\Utility\ArrayToTextTable::AlignLeft);
//處理表格數據格式
$renderer->setFormatter(function (&$value,$key){
if($key == 'sex'){
if(empty($value)){
$value = '未知性別';
}
}else if($key == 'email'){
if(empty($value)){
$value = '未知郵箱';
}
}
});
$table = $renderer->getTable();
echo $renderer;
? ps: 執行的時候請用命令行的模式運行;如若遇到表格的外框線沒有對齊,請檢查中文字體和英文的字體所占用的空間比是否為2:1。