TableArray – 多功能數據處理工具

一、TableArray概述

TableArray是PHP語言的一個多功能數據處理工具,它提供了對數組、CSV文件、Excel文件等多種數據結構的處理能力,能夠實現數據的轉換、篩選、排序、分組統計、條件聚合、數據透視、數據逆透視等功能。TableArray採用了鏈式調用的編程模式,使得複雜數據處理任務的實現變得簡單、直觀、高效。

// Example 1: 計算某一列的平均值和總和
require_once('TableArray.php');
$data = array(
    array('name' => 'Tom', 'age' => 21, 'gpa' => 3.5),
    array('name' => 'Jerry', 'age' => 22, 'gpa' => 3.8),
    array('name' => 'Mary', 'age' => 20, 'gpa' => 3.6),
    array('name' => 'John', 'age' => 23, 'gpa' => 3.4)
);
$ta = new TableArray($data);
$avg_gpa = $ta->avg('gpa');
$total_gpa = $ta->sum('gpa');
echo "Avg GPA: $avg_gpa\nTotal GPA: $total_gpa\n";

二、TableArray的數據類型支持

TableArray支持多種數據類型的讀取和處理,包括數組、CSV文件、Excel文件、MySQL資料庫等。

1. 數組

數組是TableArray最基本、也是最常用的數據類型。TableArray能夠輕鬆地讀取和處理二維數組或關聯數組。以下是一個使用TableArray處理數組的例子。

// Example 2: 對數組進行排序和分頁
require_once('TableArray.php');
$data = array(
    array('name' => 'Tom', 'age' => 21, 'gpa' => 3.5),
    array('name' => 'Jerry', 'age' => 22, 'gpa' => 3.8),
    array('name' => 'Mary', 'age' => 20, 'gpa' => 3.6),
    array('name' => 'John', 'age' => 23, 'gpa' => 3.4)
);
$ta = new TableArray($data);
$ta->sort('gpa', 'desc')->page(2, 2);
print_r($ta->toArray());

2. CSV文件

CSV文件是一種常見的數據存儲格式,TableArray能夠讀取並處理CSV文件。以下是一個使用TableArray處理CSV文件的例子。

// Example 3: 對CSV文件進行數據透視
require_once('TableArray.php');
$ta = TableArray::fromCsv('data.csv', true);
$ta->pivot(array('date', 'city'), 'sales', 'sum');
print_r($ta->toArray());

3. Excel文件

Excel文件是一種常見的數據存儲格式,TableArray能夠讀取並處理Excel文件。以下是一個使用TableArray處理Excel文件的例子。

// Example 4: 對Excel文件進行數據逆透視
require_once('TableArray.php');
$ta = TableArray::fromExcel('data.xlsx', true);
$ta->unpivot(array('date', 'city'), array('product', 'sales'), ',');
print_r($ta->toArray());

4. MySQL資料庫

MySQL資料庫是一種常用的數據存儲方式,TableArray能夠讀取並處理MySQL資料庫中的數據。以下是一個使用TableArray處理MySQL資料庫的例子。

// Example 5: 對MySQL資料庫中的數據進行篩選和分組統計
require_once('TableArray.php');
$ta = TableArray::fromMysql('host', 'username', 'password', 'database', 'table');
$ta->where('age', '>', 20)->groupBy('gender')->sum('income');
print_r($ta->toArray());

三、TableArray的數據處理能力

TableArray提供了多種數據處理能力,以下列舉其中幾個常用的功能。

1. 數據轉換

TableArray能夠將數據從一種格式轉換為另一種格式,例如將數組轉換為CSV文件、將CSV文件轉換為Excel文件等。

// Example 6: 將數組轉換為CSV文件並保存到本地文件
require_once('TableArray.php');
$data = array(
    array('name' => 'Tom', 'age' => 21, 'gpa' => 3.5),
    array('name' => 'Jerry', 'age' => 22, 'gpa' => 3.8),
    array('name' => 'Mary', 'age' => 20, 'gpa' => 3.6),
    array('name' => 'John', 'age' => 23, 'gpa' => 3.4)
);
$ta = new TableArray($data);
$ta->toCsv('data.csv');

2. 數據篩選

TableArray能夠根據條件篩選出符合條件的數據,例如只保留某一列滿足條件的數據。

// Example 7: 篩選出某一列滿足條件的數據
require_once('TableArray.php');
$data = array(
    array('name' => 'Tom', 'age' => 21, 'gpa' => 3.5),
    array('name' => 'Jerry', 'age' => 22, 'gpa' => 3.8),
    array('name' => 'Mary', 'age' => 20, 'gpa' => 3.6),
    array('name' => 'John', 'age' => 23, 'gpa' => 3.4)
);
$ta = new TableArray($data);
$ta->where('gpa', '>', 3.5)->select('name', 'age');
print_r($ta->toArray());

3. 數據聚合

TableArray能夠對數據進行聚合統計,例如對某一列求和、求平均值等。

// Example 8: 計算某一列的平均值和總和
require_once('TableArray.php');
$data = array(
    array('name' => 'Tom', 'age' => 21, 'gpa' => 3.5),
    array('name' => 'Jerry', 'age' => 22, 'gpa' => 3.8),
    array('name' => 'Mary', 'age' => 20, 'gpa' => 3.6),
    array('name' => 'John', 'age' => 23, 'gpa' => 3.4)
);
$ta = new TableArray($data);
$avg_gpa = $ta->avg('gpa');
$total_gpa = $ta->sum('gpa');
echo "Avg GPA: $avg_gpa\nTotal GPA: $total_gpa\n";

4. 數據透視

數據透視是一種常用的數據分析方式,TableArray能夠對數據進行透視,將多維數據展開為二維表格,便於數據分析。

// Example 9: 對數據進行透視
require_once('TableArray.php');
$data = array(
    array('date' => '2022-01-01', 'city' => 'Beijing', 'product' => 'apple', 'sales' => 100),
    array('date' => '2022-01-01', 'city' => 'Beijing', 'product' => 'orange', 'sales' => 200),
    array('date' => '2022-01-01', 'city' => 'Shanghai', 'product' => 'apple', 'sales' => 150),
    array('date' => '2022-01-01', 'city' => 'Shanghai', 'product' => 'orange', 'sales' => 250),
    array('date' => '2022-01-02', 'city' => 'Beijing', 'product' => 'apple', 'sales' => 120),
    array('date' => '2022-01-02', 'city' => 'Beijing', 'product' => 'orange', 'sales' => 180),
    array('date' => '2022-01-02', 'city' => 'Shanghai', 'product' => 'apple', 'sales' => 170),
    array('date' => '2022-01-02', 'city' => 'Shanghai', 'product' => 'orange', 'sales' => 230)
);
$ta = new TableArray($data);
$ta->pivot(array('date', 'city'), 'sales', 'sum');
print_r($ta->toArray());

5. 數據逆透視

數據逆透視是數據透視的逆操作,TableArray能夠將透視後的數據恢復成原始數據結構。

// Example 10: 對透視後的數據進行逆透視
require_once('TableArray.php');
$data = array(
    array('date' => '2022-01-01', 'Beijing_apple_sales' => 100, 'Beijing_orange_sales' => 200, 'Shanghai_apple_sales' => 150, 'Shanghai_orange_sales' => 250),
    array('date' => '2022-01-02', 'Beijing_apple_sales' => 120, 'Beijing_orange_sales' => 180, 'Shanghai_apple_sales' => 170, 'Shanghai_orange_sales' => 230)
);
$ta = new TableArray($data);
$ta->unpivot(array('date', 'city'), array('product', 'sales'), '_');
print_r($ta->toArray());

原創文章,作者:IWJGI,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/334320.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
IWJGI的頭像IWJGI
上一篇 2025-02-05 13:05
下一篇 2025-02-05 13:05

相關推薦

  • Python字典去重複工具

    使用Python語言編寫字典去重複工具,可幫助用戶快速去重複。 一、字典去重複工具的需求 在使用Python編寫程序時,我們經常需要處理數據文件,其中包含了大量的重複數據。為了方便…

    編程 2025-04-29
  • Zlios——一個多功能的開發框架

    你是否在開發過程中常常遇到同樣的問題,需要不斷去尋找解決方案?你是否想要一個多功能、易於使用的開發框架來解決這些問題?那麼,Zlios就是你需要的框架。 一、簡介 Zlios是一個…

    編程 2025-04-29
  • Python數據處理課程設計

    本文將從多個方面對Python數據處理課程設計進行詳細闡述,包括數據讀取、數據清洗、數據分析和數據可視化四個方面。通過本文的學習,讀者將能夠了解使用Python進行數據處理的基本知…

    編程 2025-04-29
  • 如何通過jstack工具列出假死的java進程

    假死的java進程是指在運行過程中出現了某些問題導致進程停止響應,此時無法通過正常的方式關閉或者重啟該進程。在這種情況下,我們可以藉助jstack工具來獲取該進程的進程號和線程號,…

    編程 2025-04-29
  • 註冊表取證工具有哪些

    註冊表取證是數字取證的重要分支,主要是獲取計算機系統中的註冊表信息,進而分析痕迹,獲取重要證據。本文將以註冊表取證工具為中心,從多個方面進行詳細闡述。 一、註冊表取證工具概述 註冊…

    編程 2025-04-29
  • Python運維工具用法介紹

    本文將從多個方面介紹Python在運維工具中的應用,包括但不限於日誌分析、自動化測試、批量處理、監控等方面的內容,希望能對Python運維工具的使用有所幫助。 一、日誌分析 在運維…

    編程 2025-04-28
  • t3.js:一個全能的JavaScript動態文本替換工具

    t3.js是一個非常流行的JavaScript動態文本替換工具,它是一個輕量級庫,能夠很容易地實現文本內容的遞增、遞減、替換、切換以及其他各種操作。在本文中,我們將從多個方面探討t…

    編程 2025-04-28
  • Trocket:打造高效可靠的遠程控制工具

    如何使用trocket打造高效可靠的遠程控制工具?本文將從以下幾個方面進行詳細的闡述。 一、安裝和使用trocket trocket是一個基於Python實現的遠程控制工具,使用時…

    編程 2025-04-28
  • gfwsq9ugn:全能編程開發工程師的必備工具

    gfwsq9ugn是一個強大的編程工具,它為全能編程開發工程師提供了一系列重要的功能和特點,下面我們將從多個方面對gfwsq9ugn進行詳細的闡述。 一、快速編寫代碼 gfwsq9…

    編程 2025-04-28
  • Spark開源項目-大數據處理的新星

    Spark是一款開源的大數據分散式計算框架,它能夠高效地處理海量數據,並且具有快速、強大且易於使用的特點。本文將從以下幾個方面闡述Spark的優點、特點及其相關使用技巧。 一、Sp…

    編程 2025-04-27

發表回復

登錄後才能評論