-
Notifications
You must be signed in to change notification settings - Fork 4
/
array_formula.bas
45 lines (34 loc) · 1.63 KB
/
array_formula.bas
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
/'
* Example of how to use the libxlsxwriter library to write simple
* array formulas.
*
* Copyright 2014-2017, John McNamara, jmcnamara@cpan.org
*
* translated by Lee June by using https://github.com/retsyo/libxlsxwriter_freebasic
'/
#include "auto_xlsxwriter.bi"
function main() as Integer
Rem Create a new workbook and add a worksheet. */
Dim as lxw_workbook ptr workbook = workbook_new("array_formula.xlsx")
Dim as lxw_worksheet ptr worksheet = workbook_add_worksheet(workbook, NULL)
Rem Write some data for the formulas. */
worksheet_write_number(worksheet, 0, 1, 500, NULL)
worksheet_write_number(worksheet, 1, 1, 10, NULL)
worksheet_write_number(worksheet, 4, 1, 1, NULL)
worksheet_write_number(worksheet, 5, 1, 2, NULL)
worksheet_write_number(worksheet, 6, 1, 3, NULL)
worksheet_write_number(worksheet, 0, 2, 300, NULL)
worksheet_write_number(worksheet, 1, 2, 15, NULL)
worksheet_write_number(worksheet, 4, 2, 20234, NULL)
worksheet_write_number(worksheet, 5, 2, 21003, NULL)
worksheet_write_number(worksheet, 6, 2, 10000, NULL)
Rem Write an array formula that returns a single value. */
worksheet_write_array_formula(worksheet, 0, 0, 0, 0, "{=SUM(B1:C1*B2:C2)}", NULL)
Rem Similar to above but using the RANGE macro. */
worksheet_write_array_formula(worksheet, RANGE("A2:A2"), "{=SUM(B1:C1*B2:C2)}", NULL)
Rem Write an array formula that returns a range of values. */
worksheet_write_array_formula(worksheet, 4, 0, 6, 0, "{=TREND(C5:C7,B5:B7)}", NULL)
workbook_close(workbook)
return 0
end Function
main()