EXCEL Analyzer

EXCEL表格分析。利用指定表格名、資料起始儲存格、表頭欄位將載入資料正規化,呈現一致的資料結構(input輸入陣列)作為 Low-Code 資料分析來源,結果寫入工作資料夾文檔

EXCEL

EXCEL輸入檔,點擊 PICK 選取檔案、鍵盤輸入工作資料夾中的EXCEL檔名,或使用 %FILENAME% 變數。

SHEET

EXCEL輸入表格名稱,留空代表為檔案中的第一個 sheet。

DATA CELL

表格資料的起點(左上)儲存格A1表示法,不包含表頭。

輸入表格的表頭欄位命名陣列為兩種 JSON 陣列表示法,第一種是簡單的一對一字串陣列,陣列中的第一個字串對應到表格的第一個表頭欄位,第二個字串則對應到第二個表頭欄位,中間不能跳過,以此類推:

["A欄表頭名稱", "B欄表頭名稱", ...] 

第二種是較為彈性的物件陣列,利用物件中的正規表達式 regexp、偏移值 offset、A1 表示法等屬性作為定位表頭欄位的依據,再以物件中的 name 屬性值作為定位到的表頭欄位名稱:

[
  {
    "regexp": "品名$",  // 找到表格資料起點上方值符合”品名“結尾的儲存格
    "name": "product"  // 將找到的儲存格做為表頭欄位,並命名為”product"
  },
  {
    "regexp": "品名$",  // 找到表格資料起點上方值符合”品名“結尾的儲存格
    "offset": 1, // 往右偏移一格
    "name": "price"  // 將找到的儲存格做為表頭欄位,並命名為"price"
  },
  {
    "A1": "C",  // 找到欄位C(以A1表示法來看)
    "name": "stock"  // 將找到的儲存格做為表頭欄位,並命名為"stock"
  }
] 

input 輸入陣列

在 input 陣列中的每個物件元素代表輸入表格的一列資料,物件中的 key 為表頭欄位,value 為該欄位在這一列資料的值。

// 印出輸入表格每筆資料的指定欄位
input.forEach((row, index) => {
  console.log(index + '. 品名:' + row.name + ', 價格:' + row.price)
})

output 輸出物件

加入 output 物件中的每個 key 將被輸出成工作資料夾中的一個 TXT 檔案,檔案名稱即為 key,文字內容為該 key 相對應的 value。

// 寫入分析結果到工作資料夾中 total.txt 
let total = 0
input.forEach((row) => total = total + row.price)
output['total'] = total

// 也可以利用 lodash 函式庫計算平均值
output['average'] = _.meanBy(input, 'price')

Last updated