[{"id":"1b88a165-2563-437e-99bb-ae30bd4b56db","tags":[{"name":"更新","color":"Coral","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"a2f84374-4a3f-4d22-96fd-765e9de495bf"}]},{"id":"a244ead7-a2c6-47a3-ac17-c5dbfa337362","tags":[{"name":"更新","color":"Coral","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"a2f84374-4a3f-4d22-96fd-765e9de495bf"}]},{"id":"33638a1c-7196-42c1-a96d-38b2d9ba8ac4","tags":[{"name":"更新","color":"Coral","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"a2f84374-4a3f-4d22-96fd-765e9de495bf"}]},{"id":"8e72e33e-b4ab-4fb3-98fc-a0b148134aed","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"86662220-9b9e-4940-9ced-d22642ea49a8","tags":[{"name":"更新","color":"Coral","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"a2f84374-4a3f-4d22-96fd-765e9de495bf"}]},{"id":"55fd3bb8-18d4-4edb-9640-ca3a365b798f","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"760b37c7-c713-4b24-b9ba-4bfe7d8437a6","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"3a083583-1d5f-492b-b450-34b2b5c775b8","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"04e73782-aa78-4dfe-a4f9-e72ed4c78a11","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"57c94653-8893-403b-a5b1-0d1e33a0bd0f","tags":[{"name":"更新","color":"Coral","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"a2f84374-4a3f-4d22-96fd-765e9de495bf"}]},{"id":"09a66339-64c0-415c-b142-0691587a8e4a","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"5b7aeac5-c755-426a-95c7-1ae8e547179a","tags":[{"name":"更新","color":"Coral","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"a2f84374-4a3f-4d22-96fd-765e9de495bf"}]},{"id":"790bc77a-9216-48fd-b8f9-fbc374ebb155","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"900e6cab-065d-4f1c-844d-efa3c074e270","tags":[{"name":"更新","color":"Coral","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"a2f84374-4a3f-4d22-96fd-765e9de495bf"}]},{"id":"0baaf91d-84f6-404c-a487-735226b6d5b6","tags":[{"name":"更新","color":"Coral","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"a2f84374-4a3f-4d22-96fd-765e9de495bf"}]},{"id":"5d37413b-3600-4da9-9700-feea54355f59","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"7ded3a22-15eb-49b8-a488-e83c2cd872eb","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"89c707ed-9841-4e53-96fb-940cc3214804","tags":[{"name":"更新","color":"Coral","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"a2f84374-4a3f-4d22-96fd-765e9de495bf"}]},{"id":"a570c8e7-07a2-47da-965b-da44fd1fa5cf","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"a5a73576-16ea-4cbc-925c-ef547389eaa5","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"69e79655-e015-4f9a-a230-2a25c988c926","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"adf3817f-7667-4a4c-8a5f-767b0b7e1e3e","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"1126cfab-6210-4e28-bee0-02c113fb7a0c","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"63c577e6-6cf9-497e-94e1-2307f7d3f498","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"24769ecd-2b08-4a85-b318-4f533bbf8393","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"2605431b-dc80-491d-886e-28981595d277","tags":[{"name":"更新","color":"Coral","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"a2f84374-4a3f-4d22-96fd-765e9de495bf"}]},{"id":"4f41e22e-eb51-49e5-aeae-a42dd6bf352c","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"aa71a884-c5bc-4842-8d6a-873dfd645167","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"b0576ca2-cb84-4390-9f95-9354ec20eda5","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"dacc7931-6785-4675-be31-80930403cf7b","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"c90d5fdf-420f-4978-8bf5-c9a2bb4334b3","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"6e6ac5b1-1501-4e28-89cc-525139488537","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"ff052704-1389-4029-bcdd-73c6cbe9f807","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"21c6131f-0f2d-41d1-9284-6ad9ee803c1f","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"64e2f4a3-2303-4bfa-8a93-6c23ef01de58","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"4a0842a3-20b1-40c3-8e00-cd5941ffdf53","tags":[{"name":"更新","color":"Coral","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"a2f84374-4a3f-4d22-96fd-765e9de495bf"}]}]
        
(Showing Draft Content)

结构化引用公式

SpreadJS支持表中的结构化参考公式。

结构化引用公式使用关键字和表的列名来引用表中的单元格区域。

下图说明了结构化参考的组件。 此公式将总销售额和税额相加。

  • 表名是您提供的有意义的名称,用于引用实际的表数据(不包括标题和总计行)。
  • 列说明符从列标题派生,并括在方括号中。 列说明符引用列数据(不包括列标题和总数,如果有的话)。
  • 特殊项目说明符可用于引用表的特定部分,例如“总计”行。
  • 表格说明符是结构化引用的外部,在表格名称后的方括号内。
  • 结构化引用是从表名开始到表说明符结束的整个字符串。

用户可以使用特殊项目来引用表的各个区域,以便更轻松地在公式中使用。 下表列出了用户可以在结构化引用中使用的特殊项目说明符:

特殊项目 示例 参考 单元格区域
#All =DeptSales[#All] Entire table including column headers, data, and totals A1:E8
#Data =DeptSales[#Data] Data A2:E7
#Headers =DeptSales[#Headers] Header row A1:E1
#Totals =DeptSales[#Totals] Total row. Returns null if none exists A8:E8
#This Row =DeptSales[#This Row] Portion of the columns in the current row A5:E5 (current row is 5)

“ #This Row”项可以缩写为“ @”。 例如,= DeptSales [#This Row]与= DeptSales [@]相同。

“ #Data”项可以与“ #Headers”或“ #Totals”组合使用。 下表列出了示例:

特殊项目 示例 参考 单元格区域
#Headers and #Data =DeptSales[[#Headers], [#Data]] Column headers and data A1:E7
#Data and #Totals =DeptSales[[#Data], [#Totals]] Data and the total row A2:E8

如果未指定特殊项目,则将其视为数据,如下表所示:

特殊项目 示例 参考 单元格区域
None =DeptSales[] or =DeptSales Data A2:E7

列说明符表示对整个数据列的引用,但列标题和总数除外。 下表列出了列说明符:

列说明符 示例 参考 单元格区域
Single column =DeptSales[SaleAmt] "SaleAmt" column in data C2:C7
Column range =DeptSales[[SaleAmt]:[TaxAmt]] Range of column "SaleAmt" to column "TaxAmt" in data C2:E7
None =DeptSales[[#Data]] All columns in data A2:E8

所有表,列和特殊项目说明符都必须放在匹配的括号([])中。 包含其他说明符的说明符需要外部匹配括号来包围其他说明符的内部匹配括号。 如果策略之间存在冲突,则优先级从最高到最低。

以下规则适用于方括号:

  • 如果没有说明符,则可以省略表说明符括号。 例如,“ = DeptSales []”等于“ = DeptSales”。
  • 如果只有一个特殊项目或一个列说明符,则可以省略表说明符括号。 例如,“ = DeptSales [[#Data]]”等于“ = DeptSales [#Data]”,“ = DeptSales [[TaxAmt]]”等于“ = DeptSales [TaxAmt]”。
  • 如果有列说明符或特殊项目的组合,则特殊项目必须放在匹配的括号中。 例如,不允许使用“ = DeptSales [#Data,[TaxAm]]”和“ = DeptSales [#Data,#Totals]”。
  • 如果表的列标题包含以下特殊字符之一,则必须将整个列标题括在方括号中: 空格键, tab键, line break, 回车, 逗号 (,), 冒号 (:), 句号 (.), 左括号 ([) , 右括号 (]), 井号 (#), 单引号 ('), 双引号 ("), 左大括号 ({), 右大括号 (}), 美元符 ($), 尖号 (^), 连字号 (&), 星号 (*), 加号 (+), 等于号 (=), 减号 (-), 大于号(>), 小于号 (<), 和划分 (//). 例如, 如果一个列名是"#column1", 公式 "=Table1[#column1]" 是不允许的, 必须为 "=Table1['#column1]".
  • 如果有列范围说明符,则必须在括号中包含一个列说明符。 例如,不允许使用“ = Table1 [column1:column2]”,它必须是“ = Table1 [[column1]:column2]”或“ = Table1 [column1:[column2]]”或“ = Table1 [[column1]” :[column2]]”。
  • 可以省略'@'特殊括号。 例如,“ = DeptSales [@,TaxAmt]”等于“ = DeptSales [[@],TaxAmt]”。

以下一般规则也适用:

  • 所有表,列和特殊项目说明符都不区分大小写。
  • 以下字符具有特殊含义,需要使用单引号(')作为转义字符:左括号([),右括号(]),井号(#)和单引号(')。 例如,不允许使用“ = Table1 [colu#mn1]”,它必须是“ = Table1 [colu'#mn1]”。
  • 使用逗号(,)分隔组合的特殊项目和列说明符。 例如,“ = DeptSales [[#Data],[#Totals],TaxAmt]”。
  • 特殊项目和列说明符之间的顺序是独立的。 例如,“ = DeptSales [[#Data],[#Totals],TaxAmt]”等于“ = DeptSales [[#Totals],TaxAmt,[#Data]]”。
  • 可以省略'@'特殊项目后面的逗号(,)。 例如,“ = DeptSales [@,TaxAmt]”等于“ = DeptSales [@TaxAmt]”。

您可以使用 setColumnDataFormula setColumnFormula 方法。 您还可以在表格区域之外的公式中引用表格数据。 例如,activeSheet.getCell(7,1).formula(“ SUM(Table1 [SubTotal])”);。 设置的最后一个公式在列公式和单元格公式之间具有优先权。

公式中的列说明符不适用于页眉和页脚中的单元格。

公式中的列说明符不适用于页眉和页脚中的单元格。

示例代码

下面的示例创建一个表格,并使用结构化参考公式创建总计。

activeSheet.tables.add("Table1", 0, 0, 4, 3, GC.Spread.Sheets.Tables.TableThemes.dark1);
activeSheet.getCell(0,0).text("Value1");
activeSheet.getCell(0,1).text("Value2");
activeSheet.getCell(0,2).text("SubTotal");
activeSheet.getCell(1,0).text("1");
activeSheet.getCell(2,0).text("2");
activeSheet.getCell(3,0).text("3");
activeSheet.getCell(1,1).text("5");
activeSheet.getCell(2,1).text("5");
activeSheet.getCell(3,1).text("5");
var sTable = activeSheet.tables.findByName("Table1").setColumnDataFormula(2, "=[Value1]*[Value2]");
sTable.showFooter(true);
//设置页脚值
sTable.setColumnValue(0, "Total");
sTable.setColumnFormula(2, "SUM(Table1[SubTotal])");
activeSheet.getColumn(0).width(80);
activeSheet.getColumn(1).width(80);
activeSheet.getColumn(2).width(80);
//activeSheet.getCell(7,1).formula("SUM(Table1[SubTotal])");