-
Notifications
You must be signed in to change notification settings - Fork 72
/
Copy pathclass_XL.ahk
558 lines (557 loc) · 50 KB
/
class_XL.ahk
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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
/************************************************************************
* @file: XL.ahk
* @description: High performance library for reading and writing Excel(xls,xlsx) files.
* @author thqby
* @date 2021/10/04
* @version 1.1.1
* @documentation https://www.libxl.com/documentation.html
* @enum var
* Color {BLACK = 8, WHITE, RED, BRIGHTGREEN, BLUE, YELLOW, PINK, TURQUOISE, DARKRED, GREEN, DARKBLUE, DARKYELLOW, VIOLET, TEAL, GRAY25, GRAY50, PERIWINKLE_CF, PLUM_CF, IVORY_CF, LIGHTTURQUOISE_CF, DARKPURPLE_CF, CORAL_CF, OCEANBLUE_CF, ICEBLUE_CF, DARKBLUE_CL, PINK_CL, YELLOW_CL, TURQUOISE_CL, VIOLET_CL, DARKRED_CL, TEAL_CL, BLUE_CL, SKYBLUE, LIGHTTURQUOISE, LIGHTGREEN, LIGHTYELLOW, PALEBLUE, ROSE, LAVENDER, TAN, LIGHTBLUE, AQUA, LIME, GOLD, LIGHTORANGE, ORANGE, BLUEGRAY, GRAY40, DARKTEAL, SEAGREEN, DARKGREEN, OLIVEGREEN, BROWN, PLUM, INDIGO, GRAY80, DEFAULT_FOREGROUND = 0x40, DEFAULT_BACKGROUND = 0x41, TOOLTIP = 0x51, NONE = 0x7F, AUTO = 0x7FFF}
* NumFormat {GENERAL = 0, NUMBER = 1, NUMBER_D2 = 2, NUMBER_SEP = 3, NUMBER_SEP_D2 = 4, CURRENCY_NEGBRA = 5, CURRENCY_NEGBRARED = 6, CURRENCY_D2_NEGBRA = 7, CURRENCY_D2_NEGBRARED = 8, PERCENT = 9, PERCENT_D2 = 10, SCIENTIFIC_D2 = 11, FRACTION_ONEDIG = 12, FRACTION_TWODIG = 13, DATE = 14, CUSTOM_D_MON_YY = 15, CUSTOM_D_MON = 16, CUSTOM_MON_YY = 17, CUSTOM_HMM_AM = 18, CUSTOM_HMMSS_AM = 19, CUSTOM_HMM = 20, CUSTOM_HMMSS = 21, CUSTOM_MDYYYY_HMM = 22, NUMBER_SEP_NEGBRA=37 = 23, NUMBER_SEP_NEGBRARED = 24, NUMBER_D2_SEP_NEGBRA = 25, NUMBER_D2_SEP_NEGBRARED = 26, ACCOUNT = 27, ACCOUNTCUR = 28, ACCOUNT_D2 = 29, ACCOUNT_D2_CUR = 30, CUSTOM_MMSS = 31, CUSTOM_H0MMSS = 32, CUSTOM_MMSS0 = 33, CUSTOM_000P0E_PLUS0 = 34, TEXT = 35}
* AlignH {GENERAL = 0, LEFT = 1, CENTER = 2, RIGHT = 3, FILL = 4, JUSTIFY = 5, MERGE = 6, DISTRIBUTED = 7}
* AlignV {TOP = 0, CENTER = 1, BOTTOM = 2, JUSTIFY = 2, DISTRIBUTED = 3}
* BorderStyle {NONE, THIN, MEDIUM, DASHED, DOTTED, THICK, DOUBLE, HAIR, MEDIUMDASHED, DASHDOT, MEDIUMDASHDOT, DASHDOTDOT, MEDIUMDASHDOTDOT, SLANTDASHDOT}
* BorderDiagonal {NONE = 0, DOWN = 1, UP = 2, BOTH = 3}
* FillPattern {NONE, SOLID, GRAY50, GRAY75, GRAY25, HORSTRIPE, VERSTRIPE, REVDIAGSTRIPE, DIAGSTRIPE, DIAGCROSSHATCH, THICKDIAGCROSSHATCH, THINHORSTRIPE, THINVERSTRIPE, THINREVDIAGSTRIPE, THINDIAGSTRIPE, THINHORCROSSHATCH, THINDIAGCROSSHATCH, GRAY12P5, GRAY6P25}
* Script {NORMAL = 0, SUPER = 1, SUB = 2}
* Underline {NONE = 0, SINGLE, DOUBLE, SINGLEACC = 0x21, DOUBLEACC = 0x22}
* Paper {DEFAULT, LETTER, LETTERSMALL, TABLOID, LEDGER, LEGAL, STATEMENT, EXECUTIVE, A3, A4, A4SMALL, A5, B4, B5, FOLIO, QUATRO, 10x14, 10x17, NOTE, ENVELOPE_9, ENVELOPE_10, ENVELOPE_11, ENVELOPE_12, ENVELOPE_14, C_SIZE, D_SIZE, E_SIZE, ENVELOPE_DL, ENVELOPE_C5, ENVELOPE_C3, ENVELOPE_C4, ENVELOPE_C6, ENVELOPE_C65, ENVELOPE_B4, ENVELOPE_B5, ENVELOPE_B6, ENVELOPE, ENVELOPE_MONARCH, US_ENVELOPE, FANFOLD, GERMAN_STD_FANFOLD, GERMAN_LEGAL_FANFOLD, B4_ISO, JAPANESE_POSTCARD, 9x11, 10x11, 15x11, ENVELOPE_INVITE, US_LETTER_EXTRA = 50, US_LEGAL_EXTRA, US_TABLOID_EXTRA, A4_EXTRA, LETTER_TRANSVERSE, A4_TRANSVERSE, LETTER_EXTRA_TRANSVERSE, SUPERA, SUPERB, US_LETTER_PLUS, A4_PLUS, A5_TRANSVERSE, B5_TRANSVERSE, A3_EXTRA, A5_EXTRA, B5_EXTRA, A2, A3_TRANSVERSE, A3_EXTRA_TRANSVERSE, JAPANESE_DOUBLE_POSTCARD, A6, JAPANESE_ENVELOPE_KAKU2, JAPANESE_ENVELOPE_KAKU3, JAPANESE_ENVELOPE_CHOU3, JAPANESE_ENVELOPE_CHOU4, LETTER_ROTATED, A3_ROTATED, A4_ROTATED, A5_ROTATED, B4_ROTATED, B5_ROTATED, JAPANESE_POSTCARD_ROTATED, DOUBLE_JAPANESE_POSTCARD_ROTATED, A6_ROTATED, JAPANESE_ENVELOPE_KAKU2_ROTATED, JAPANESE_ENVELOPE_KAKU3_ROTATED, JAPANESE_ENVELOPE_CHOU3_ROTATED, JAPANESE_ENVELOPE_CHOU4_ROTATED, B6, B6_ROTATED, 12x11, JAPANESE_ENVELOPE_YOU4, JAPANESE_ENVELOPE_YOU4_ROTATED, PRC16K, PRC32K, PRC32K_BIG, PRC_ENVELOPE1, PRC_ENVELOPE2, PRC_ENVELOPE3, PRC_ENVELOPE4, PRC_ENVELOPE5, PRC_ENVELOPE6, PRC_ENVELOPE7, PRC_ENVELOPE8, PRC_ENVELOPE9, PRC_ENVELOPE10, PRC16K_ROTATED, PRC32K_ROTATED, PRC32KBIG_ROTATED, PRC_ENVELOPE1_ROTATED, PRC_ENVELOPE2_ROTATED, PRC_ENVELOPE3_ROTATED, PRC_ENVELOPE4_ROTATED, PRC_ENVELOPE5_ROTATED, PRC_ENVELOPE6_ROTATED, PRC_ENVELOPE7_ROTATED, PRC_ENVELOPE8_ROTATED, PRC_ENVELOPE9_ROTATED, PRC_ENVELOPE10_ROTATED}
* SheetType {SHEET, CHART, UNKNOWN }
* CellType {EMPTY, NUMBER, STRING, BOOLEAN, BLANK, ERROR, STRICTDATE}
* ErrorType {NULL = 0x0, DIV_0 = 0x7, VALUE = 0x0F, REF = 0x17, NAME = 0x1D, NUM = 0x24, NA = 0x2A, NOERROR = 0xFF}
* PictureType {PNG, JPEG, GIF, WMF, DIB, EMF, PICT, TIFF, ERROR = 0xFF}
* SheetState {VISIBLE, HIDDEN, VERYHIDDEN}
* Scope {UNDEFINED = -2, WORKBOOK = -1}
* Position {MOVE_AND_SIZE, ONLY_MOVE, ABSOLUTE}
* Operator { EQUAL, GREATER_THAN, GREATER_THAN_OR_EQUAL, LESS_THAN, LESS_THAN_OR_EQUAL, NOT_EQUAL }
* Filter { VALUE, TOP10, CUSTOM, DYNAMIC, COLOR, ICON, EXT, NOT_SET }
* IgnoredError { NO_ERROR = 0, EVAL_ERROR = 1, EMPTY_CELLREF = 2, NUMBER_STORED_AS_TEXT = 4, INCONSIST_RANGE = 8, INCONSIST_FMLA = 16, TWODIG_TEXTYEAR = 32, UNLOCK_FMLA = 64, DATA_VALIDATION = 128 }
* EnhancedProtection { DEFAULT = -1, ALL = 0, OBJECTS = 1, SCENARIOS = 2, FORMAT_CELLS = 4, FORMAT_COLUMNS = 8, FORMAT_ROWS = 16, INSERT_COLUMNS = 32, INSERT_ROWS = 64, INSERT_HYPERLINKS = 128, DELETE_COLUMNS = 256, DELETE_ROWS = 512, SEL_LOCKED_CELLS = 1024, SORT = 2048, AUTOFILTER = 4096, PIVOTTABLES = 8192, SEL_UNLOCKED_CELLS = 16384 }
* DataValidationType { TYPE_NONE, TYPE_WHOLE, TYPE_DECIMAL, TYPE_LIST, TYPE_DATE, TYPE_TIME, TYPE_TEXTLENGTH, TYPE_CUSTOM }
* DataValidationOperator { OP_BETWEEN, OP_NOTBETWEEN, OP_EQUAL, OP_NOTEQUAL, OP_LESSTHAN, OP_LESSTHANOREQUAL, OP_GREATERTHAN, OP_GREATERTHANOREQUAL }
* DataValidationErrorStyle { ERRSTYLE_STOP, ERRSTYLE_WARNING, ERRSTYLE_INFORMATION }
* CalcModeType { MANUAL, AUTO, AUTONOTABLE }
***********************************************************************/
class XL {
static _ := DllCall('LoadLibrary', 'str', A_LineFile '\..\' (A_PtrSize * 8) 'bit\libxl.dll', 'ptr')
static Load(path) {
if !FileExist(path)
throw Error('Excel file does not exist.')
SplitPath(path, , , &ext), handle := 0
handle := ext = 'xlsx' ? DllCall('libxl\xlCreateXMLBook', 'cdecl ptr') : DllCall('libxl\xlCreateBook', 'cdecl ptr')
book := XL.IBook(handle)
if (book.load(path))
return (book.setKey('GCCG', 'windows-282123090cc0e6036db16b60a1o3p0h9'), book)
book.release()
throw Error('Failed to load')
}
static New(ext := 'xlsx') {
IO := XL.IBook(ext = 'xlsx' ? DllCall('libxl\xlCreateXMLBook', 'cdecl ptr') : DllCall('libxl\xlCreateBook', 'cdecl ptr'))
return (IO.setKey('GCCG', 'windows-282123090cc0e6036db16b60a1o3p0h9'), IO)
}
class IBase {
ptr := 0, parent := 0
__New(handle, parent := 0) => (this.parent := parent, this.ptr := handle)
}
class IAutoFilter extends XL.IBase {
getRef(&rowFirst, &rowLast, &colFirst, &colLast) => DllCall('libxl\xlAutoFilterGetRef', 'ptr', this, 'int*', &rowFirst := 0, 'int*', &rowLast := 0, 'int*', &colFirst := 0, 'int*', &colLast := 0, 'cdecl int')
setRef(rowFirst, rowLast, colFirst, colLast) => DllCall('libxl\xlAutoFilterSetRef', 'ptr', this, 'int', rowFirst, 'int', rowLast, 'int', colFirst, 'int', colLast, 'cdecl')
column(colId) => XL.IFilterColumn(DllCall('libxl\xlAutoFilterColumn', 'ptr', this, 'int', colId, 'cdecl ptr'))
columnSize() => DllCall('libxl\xlAutoFilterColumnSize', 'ptr', this, 'cdecl int')
columnByIndex(index) => XL.IFilterColumn(DllCall('libxl\xlAutoFilterColumnByIndex', 'ptr', this, 'int', index, 'cdecl ptr'))
getSortRange(&rowFirst, &rowLast, &colFirst, &colLast) => DllCall('libxl\xlAutoFilterGetSortRange', 'ptr', this, 'int*', &rowFirst := 0, 'int*', &rowLast := 0, 'int*', &colFirst := 0, 'int*', &colLast := 0, 'cdecl int')
getSort(&columnIndex, &descending) => DllCall('libxl\xlAutoFilterGetSort', 'ptr', this, 'int*', &columnIndex := 0, 'int*', &descending := 0, 'cdecl int')
setSort(columnIndex, descending := false) => DllCall('libxl\xlAutoFilterSetSort', 'ptr', this, 'int', columnIndex, 'int', descending, 'cdecl int')
}
class IBook extends XL.IBase {
path := ''
active => this.getSheet(this.activeSheet())
__Item[it] {
get {
count := this.sheetCount()
if IsNumber(it) {
if (it < 0 && it >= count)
throw Error('Invalid index')
return this.getSheet(it)
}
Loop count
if (this.getSheetName(A_Index - 1) = it)
return this.getSheet(A_Index - 1)
throw Error('table ' it ' does not exist')
}
}
activeSheet() => DllCall('libxl\xlBookActiveSheet', 'ptr', this, 'cdecl int')
addCustomNumFormat(customNumFormat) => DllCall('libxl\xlBookAddCustomNumFormat', 'ptr', this, 'str', customNumFormat, 'cdecl int')
addFont(initFont := 0) => XL.IFont(DllCall('libxl\xlRichStringAddFont', 'ptr', this, 'ptr', initFont, 'cdecl ptr'))
addFormat(initFormat := 0) => XL.IFormat(DllCall('libxl\xlBookAddFormat', 'ptr', this, 'ptr', initFormat, 'cdecl ptr'))
addPicture(filename) => DllCall('libxl\xlBookAddPicture', 'ptr', this, 'str', filename, 'cdecl int')
addPicture2(data, size) => DllCall('libxl\xlBookAddPicture2', 'ptr', this, 'ptr', data, 'uint', size, 'cdecl int')
addPictureAsLink(filename, insert := false) => DllCall('libxl\xlBookAddPictureAsLink', 'ptr', this, 'str', filename, 'int', insert, 'cdecl int')
addRichString() => XL.IRichString(DllCall('libxl\xlBookAddRichString', 'ptr', this, 'cdecl ptr'))
addSheet(name, initSheet := 0) => XL.ISheet(DllCall('libxl\xlBookAddSheet', 'ptr', this, 'str', name, 'ptr', initSheet, 'cdecl ptr'), this)
biffVersion() => DllCall('libxl\xlBookBiffVersion', 'ptr', this, 'cdecl int')
calcMode() => DllCall('libxl\xlBookCalcMode', 'ptr', this, 'cdecl int')
colorPack(red, green, blue) => DllCall('libxl\xlBookColorPack', 'ptr', this, 'int', red, 'int', green, 'int', blue, 'cdecl int')
colorUnpack(color, &red, &green, &blue) => DllCall('libxl\xlBookColorUnpack', 'ptr', this, 'int', color, 'int*', &red := 0, 'int*', &green := 0, 'int*', &blue := 0, 'cdecl')
customNumFormat(fmt) => DllCall('libxl\xlBookCustomNumFormat', 'ptr', this, 'int', fmt, 'cdecl str')
datePack(year, month, day, hour := 0, min := 0, sec := 0, msec := 0) => DllCall('libxl\xlBookDatePack', 'ptr', this, 'int', year, 'int', month, 'int', day, 'int', hour, 'int', min, 'int', sec, 'int', msec, 'cdecl double')
dateUnpack(value, &year, &month, &day, &hour := 0, &min := 0, &sec := 0, &msec := 0) => DllCall('libxl\xlBookDateUnpack', 'ptr', this, 'double', value, 'int*', &year := 0, 'int*', &month := 0, 'int*', &day := 0, 'int*', &hour := 0, 'int*', &min := 0, 'int*', &sec := 0, 'int*', &msec := 0, 'cdecl int')
defaultFont(&fontSize) => DllCall('libxl\xlBookDefaultFont', 'ptr', this, 'int*', &fontSize := 0, 'cdecl str')
delSheet(index) => DllCall('libxl\xlBookDelSheet', 'ptr', this, 'int', index, 'cdecl int')
errorMessage() => DllCall('libxl\xlBookErrorMessage', 'ptr', this, 'cdecl astr')
font(index) => XL.IFont(DllCall('libxl\xlBookFont', 'ptr', this, 'int', index, 'cdecl ptr'))
fontSize() => DllCall('libxl\xlBookFontSize', 'ptr', this, 'cdecl int')
format(index) => XL.IFormat(DllCall('libxl\xlBookFormat', 'ptr', this, 'int', index, 'cdecl ptr'))
formatSize() => DllCall('libxl\xlBookFormatSize', 'ptr', this, 'cdecl int')
getPicture(index, &data, &size) => DllCall('libxl\xlBookGetPicture', 'ptr', this, 'int', index, 'ptr*', &data := 0, 'uint*', &size := 0, 'cdecl int')
getSheet(index) => XL.ISheet(DllCall('libxl\xlBookGetSheet', 'ptr', this, 'int', index, 'cdecl ptr'), this)
getSheetName(index) => DllCall('libxl\xlBookGetSheetName', 'ptr', this, 'int', index, 'cdecl str')
insertSheet(index, name, initSheet := 0) => XL.ISheet(DllCall('libxl\xlBookInsertSheet', 'ptr', this, 'int', index, 'str', name, 'ptr', initSheet, 'cdecl ptr'), this)
isDate1904() => DllCall('libxl\xlBookIsDate1904', 'ptr', this, 'cdecl int')
isTemplate() => DllCall('libxl\xlBookIsTemplate', 'ptr', this, 'cdecl int')
load(filename, tempFile := '') => (this.path := filename, tempFile ? DllCall('libxl\xlBookLoadUsingTempFile', 'ptr', this, 'str', filename, 'str', tempFile, 'cdecl int') : DllCall('libxl\xlBookLoad', 'ptr', this, 'str', filename, 'cdecl int'))
loadInfo(filename) => DllCall('libxl\xlBookLoadInfo', 'ptr', this, 'str', filename, 'cdecl int')
loadPartially(filename, sheetIndex, firstRow, lastRow, tempFile := '') => (tempFile ? DllCall('libxl\xlBookLoadPartiallyUsingTempFile', 'ptr', this, 'str', filename, 'int', sheetIndex, 'int', firstRow, 'int', lastRow, 'str', tempFile, 'cdecl int') : DllCall('libxl\xlBookLoadPartially', 'ptr', this, 'str', filename, 'int', sheetIndex, 'int', firstRow, 'int', lastRow, 'cdecl int'))
loadRaw(data, size, sheetIndex := -1, firstRow := -1, lastRow := -1) => (sheetIndex = -1 ? DllCall('libxl\xlBookLoadRaw', 'ptr', this, 'ptr', data, 'uint', size, 'cdecl int') : DllCall('libxl\xlBookLoadRawPartially', 'ptr', this, 'astr', data, 'uint', size, 'int', sheetIndex, 'int', firstRow, 'int', lastRow, 'cdecl int'))
loadSheet(filename, sheetIndex, tempFile := '') => (this.load(filename, tempFile), this.setActiveSheet(sheetIndex))
loadWithoutEmptyCells(filename) => DllCall('libxl\xlBookLoadWithoutEmptyCells', 'ptr', this, 'str', filename, 'cdecl int')
moveSheet(srcIndex, dstIndex) => DllCall('libxl\xlBookMoveSheet', 'ptr', this, 'int', srcIndex, 'int', dstIndex, 'cdecl int')
pictureSize() => DllCall('libxl\xlSheetPictureSize', 'ptr', this, 'cdecl int')
refR1C1() => DllCall('libxl\xlBookRefR1C1', 'ptr', this, 'cdecl int')
release() => (this.ptr ? (DllCall('libxl\xlBookRelease', 'ptr', this, 'cdecl'), this.ptr := 0) : 0)
rgbMode() => DllCall('libxl\xlBookRgbMode', 'ptr', this, 'cdecl int')
save(filename := '', useTempFile := false) {
filename := filename || this.path
if !(useTempFile ? DllCall('libxl\xlBookSaveUsingTempFile', 'ptr', this, 'str', filename, 'int', useTempFile, 'cdecl int') : DllCall('libxl\xlBookSave', 'ptr', this, 'str', filename, 'cdecl int'))
throw Error(this.errorMessage())
}
saveRaw(&data, &size) => DllCall('libxl\xlBookSaveRaw', 'ptr', this, 'ptr*', &data := 0, 'uint*', &size := 0, 'cdecl int')
setActiveSheet(index) => DllCall('libxl\xlBookSetActiveSheet', 'ptr', this, 'int', index, 'cdecl')
setCalcMode(CalcMode) => DllCall('libxl\xlBookSetCalcMode', 'ptr', this, 'int', calcMode, 'cdecl')
setDate1904(date1904 := true) => DllCall('libxl\xlBookSetDate1904', 'ptr', this, 'int', date1904, 'cdecl')
setDefaultFont(fontName, fontSize) => DllCall('libxl\xlBookSetDefaultFont', 'ptr', this, 'str', fontName, 'int', fontSize, 'cdecl')
setKey(name, key) => DllCall('libxl\xlBookSetKey', 'ptr', this, 'str', name, 'str', key, 'cdecl')
setLocale(locale) => DllCall('libxl\xlBookSetLocale', 'ptr', this, 'astr', locale, 'cdecl int')
setRefR1C1(refR1C1 := true) => DllCall('libxl\xlBookSetRefR1C1', 'ptr', this, 'int', refR1C1, 'cdecl')
setRgbMode(rgbMode := true) => DllCall('libxl\xlBookSetRgbMode', 'ptr', this, 'int', rgbMode, 'cdecl')
setTemplate(tmpl := true) => DllCall('libxl\xlBookSetTemplate', 'ptr', this, 'int', tmpl, 'cdecl')
sheetCount() => DllCall('libxl\xlBookSheetCount', 'ptr', this, 'cdecl int')
sheetType(index) => DllCall('libxl\xlBookSheetType', 'ptr', this, 'int', index, 'cdecl int')
version() => DllCall('libxl\xlBookVersion', 'ptr', this, 'cdecl int')
__Delete() => this.release()
}
class IFilterColumn extends XL.IBase {
index() => DllCall('libxl\xlFilterColumnIndex', 'ptr', this, 'cdecl int')
filterType() => DllCall('libxl\xlFilterColumnFilterType', 'ptr', this, 'cdecl int')
filterSize() => DllCall('libxl\xlFilterColumnFilterSize', 'ptr', this, 'cdecl int')
filter(index) => DllCall('libxl\xlFilterColumnFilter', 'ptr', this, 'int', index, 'cdecl str')
addFilter(value) => DllCall('libxl\xlFilterColumnAddFilter', 'ptr', this, 'str', value, 'cdecl')
getTop10(&value, &top, &percent) => DllCall('libxl\xlFilterColumnGetTop10', 'ptr', this, 'double*', &value := 0, 'int*', &top := 0, 'int*', &percent := 0, 'cdecl int')
setTop10(value, top := true, percent := false) => DllCall('libxl\xlFilterColumnSetTop10', 'ptr', this, 'double', value, 'int', top, 'int', percent, 'cdecl')
getCustomFilter(&op1, &v1, &op2, &v2, &andOp) => DllCall('libxl\xlFilterColumnGetCustomFilter', 'ptr', this, 'int*', &op1 := 0, 'str*', &v1 := '', 'int*', &op2 := 0, 'str*', &v2 := '', 'int*', &andOp := 0, 'cdecl int')
setCustomFilter(op1, v1, op2 := 0, v2 := '', andOp := false) => DllCall('libxl\xlFilterColumnSetCustomFilterEx', 'ptr', this, 'int', op1, 'str', v1, 'int', op2, 'str', v2, 'int', andOp, 'cdecl')
clear() => DllCall('libxl\xlFilterColumnClear', 'ptr', this, 'cdecl')
}
class IFont extends XL.IBase {
size() => DllCall('libxl\xlFontSize', 'ptr', this, 'cdecl int')
setSize(size) => DllCall('libxl\xlFontSetSize', 'ptr', this, 'int', size, 'cdecl')
italic() => DllCall('libxl\xlFontItalic', 'ptr', this, 'cdecl int')
setItalic(italic := true) => DllCall('libxl\xlFontSetItalic', 'ptr', this, 'int', italic, 'cdecl')
strikeOut() => DllCall('libxl\xlFontStrikeOut', 'ptr', this, 'cdecl int')
setStrikeOut(strikeOut := true) => DllCall('libxl\xlFontSetStrikeOut', 'ptr', this, 'int', strikeOut, 'cdecl')
color() => DllCall('libxl\xlFontColor', 'ptr', this, 'cdecl int')
setColor(Color) => DllCall('libxl\xlFontSetColor', 'ptr', this, 'int', color, 'cdecl')
bold() => DllCall('libxl\xlFontBold', 'ptr', this, 'cdecl int')
setBold(bold) => DllCall('libxl\xlFontSetBold', 'ptr', this, 'int', bold, 'cdecl')
script() => DllCall('libxl\xlFontScript', 'ptr', this, 'cdecl int')
setScript(Script) => DllCall('libxl\xlFontSetScript', 'ptr', this, 'int', script, 'cdecl')
underline() => DllCall('libxl\xlFontUnderline', 'ptr', this, 'cdecl int')
setUnderline(Underline) => DllCall('libxl\xlFontSetUnderline', 'ptr', this, 'int', underline, 'cdecl')
name() => DllCall('libxl\xlFontName', 'ptr', this, 'cdecl str')
setName(name) => DllCall('libxl\xlFontSetName', 'ptr', this, 'str', name, 'cdecl')
}
class IFormat extends XL.IBase {
font() => XL.IFont(DllCall('libxl\xlFormatFont', 'ptr', this, 'cdecl ptr'))
setFont(font) => DllCall('libxl\xlFormatSetFont', 'ptr', this, 'ptr', font, 'cdecl int')
numFormat() => DllCall('libxl\xlFormatNumFormat', 'ptr', this, 'cdecl int')
setNumFormat(numFormat) => DllCall('libxl\xlFormatSetNumFormat', 'ptr', this, 'int', numFormat, 'cdecl')
alignH() => DllCall('libxl\xlFormatAlignH', 'ptr', this, 'cdecl int')
setAlignH(Align) => DllCall('libxl\xlFormatSetAlignH', 'ptr', this, 'int', align, 'cdecl')
alignV() => DllCall('libxl\xlFormatAlignV', 'ptr', this, 'cdecl int')
setAlignV(Align) => DllCall('libxl\xlFormatSetAlignV', 'ptr', this, 'int', align, 'cdecl')
wrap() => DllCall('libxl\xlFormatWrap', 'ptr', this, 'cdecl int')
setWrap(wrap := true) => DllCall('libxl\xlFormatSetWrap', 'ptr', this, 'int', wrap, 'cdecl')
rotation() => DllCall('libxl\xlFormatRotation', 'ptr', this, 'cdecl int')
setRotation(rotation) => DllCall('libxl\xlFormatSetRotation', 'ptr', this, 'int', rotation, 'cdecl int')
indent() => DllCall('libxl\xlFormatIndent', 'ptr', this, 'cdecl int')
setIndent(indent) => DllCall('libxl\xlFormatSetIndent', 'ptr', this, 'int', indent, 'cdecl')
shrinkToFit() => DllCall('libxl\xlFormatShrinkToFit', 'ptr', this, 'cdecl int')
setShrinkToFit(shrinkToFit := true) => DllCall('libxl\xlFormatSetShrinkToFit', 'ptr', this, 'int', shrinkToFit, 'cdecl')
setBorder(Style := 1) => DllCall('libxl\xlFormatSetBorder', 'ptr', this, 'int', style, 'cdecl')
setBorderColor(Color) => DllCall('libxl\xlFormatSetBorderColor', 'ptr', this, 'int', color, 'cdecl')
borderLeft() => DllCall('libxl\xlFormatBorderLeft', 'ptr', this, 'cdecl int')
setBorderLeft(Style := 1) => DllCall('libxl\xlFormatSetBorderLeft', 'ptr', this, 'int', style, 'cdecl')
borderRight() => DllCall('libxl\xlFormatBorderRight', 'ptr', this, 'cdecl int')
setBorderRight(style := 1) => DllCall('libxl\xlFormatSetBorderRight', 'ptr', this, 'int', style, 'cdecl')
borderTop() => DllCall('libxl\xlFormatBorderTop', 'ptr', this, 'cdecl int')
setBorderTop(style := 1) => DllCall('libxl\xlFormatSetBorderTop', 'ptr', this, 'int', style, 'cdecl')
borderBottom() => DllCall('libxl\xlFormatBorderBottom', 'ptr', this, 'cdecl int')
setBorderBottom(style := 1) => DllCall('libxl\xlFormatSetBorderBottom', 'ptr', this, 'int', style, 'cdecl')
borderLeftColor() => DllCall('libxl\xlFormatBorderLeftColor', 'ptr', this, 'cdecl int')
setBorderLeftColor(color) => DllCall('libxl\xlFormatSetBorderLeftColor', 'ptr', this, 'int', color, 'cdecl')
borderRightColor() => DllCall('libxl\xlFormatBorderRightColor', 'ptr', this, 'cdecl int')
setBorderRightColor(color) => DllCall('libxl\xlFormatSetBorderRightColor', 'ptr', this, 'int', color, 'cdecl')
borderTopColor() => DllCall('libxl\xlFormatBorderTopColor', 'ptr', this, 'cdecl int')
setBorderTopColor(color) => DllCall('libxl\xlFormatSetBorderTopColor', 'ptr', this, 'int', color, 'cdecl')
borderBottomColor() => DllCall('libxl\xlFormatBorderBottomColor', 'ptr', this, 'cdecl int')
setBorderBottomColor(color) => DllCall('libxl\xlFormatSetBorderBottomColor', 'ptr', this, 'int', color, 'cdecl')
borderDiagonal() => DllCall('libxl\xlFormatBorderDiagonal', 'ptr', this, 'cdecl int')
setBorderDiagonal(Border) => DllCall('libxl\xlFormatSetBorderDiagonal', 'ptr', this, 'int', border, 'cdecl')
borderDiagonalStyle() => DllCall('libxl\xlFormatBorderDiagonalStyle', 'ptr', this, 'cdecl int')
setBorderDiagonalStyle(style) => DllCall('libxl\xlFormatSetBorderDiagonalStyle', 'ptr', this, 'int', style, 'cdecl')
borderDiagonalColor() => DllCall('libxl\xlFormatBorderDiagonalColor', 'ptr', this, 'cdecl int')
setBorderDiagonalColor(color) => DllCall('libxl\xlFormatSetBorderDiagonalColor', 'ptr', this, 'int', color, 'cdecl')
fillPattern() => DllCall('libxl\xlFormatFillPattern', 'ptr', this, 'cdecl int')
setFillPattern(Pattern) => DllCall('libxl\xlFormatSetFillPattern', 'ptr', this, 'int', pattern, 'cdecl')
patternForegroundColor() => DllCall('libxl\xlFormatPatternForegroundColor', 'ptr', this, 'cdecl int')
setPatternForegroundColor(color) => DllCall('libxl\xlFormatSetPatternForegroundColor', 'ptr', this, 'int', color, 'cdecl')
patternBackgroundColor() => DllCall('libxl\xlFormatPatternBackgroundColor', 'ptr', this, 'cdecl int')
setPatternBackgroundColor(color) => DllCall('libxl\xlFormatSetPatternBackgroundColor', 'ptr', this, 'int', color, 'cdecl')
locked() => DllCall('libxl\xlFormatLocked', 'ptr', this, 'cdecl int')
setLocked(locked := true) => DllCall('libxl\xlFormatSetLocked', 'ptr', this, 'int', locked, 'cdecl')
hidden() => DllCall('libxl\xlFormatHidden', 'ptr', this, 'cdecl int')
setHidden(hidden := true) => DllCall('libxl\xlFormatSetHidden', 'ptr', this, 'int', hidden, 'cdecl')
}
class IRichString extends XL.IBase {
addFont(initFont := 0) => XL.IFont(DllCall('libxl\xlRichStringAddFont', 'ptr', this, 'ptr', initFont, 'cdecl ptr'))
addText(text, font := 0) => DllCall('libxl\xlRichStringAddText', 'ptr', this, 'str', text, 'ptr', font, 'cdecl')
getText(index, &font := 0) => DllCall('libxl\xlRichStringGetText', 'ptr', this, 'int', index, 'ptr*', &font := 0, 'cdecl str')
textSize() => DllCall('libxl\xlRichStringTextSize', 'ptr', this, 'cdecl int')
}
class ISheet extends XL.IBase {
cellType(row, col) => DllCall('libxl\xlSheetCellType', 'ptr', this, 'int', row, 'int', col, 'cdecl int')
isFormula(row, col) => DllCall('libxl\xlSheetIsFormula', 'ptr', this, 'int', row, 'int', col, 'cdecl int')
cellFormat(row, col) => XL.IFormat(DllCall('libxl\xlSheetCellFormat', 'ptr', this, 'int', row, 'int', col, 'cdecl ptr'))
setCellFormat(row, col, format) => DllCall('libxl\xlSheetSetCellFormat', 'ptr', this, 'int', row, 'int', col, 'ptr', format, 'cdecl')
readStr(row, col, &format := 0) {
ret := DllCall('libxl\xlSheetReadStr', 'ptr', this, 'int', row, 'int', col, 'ptr*', &format := 0, 'cdecl str')
if (!format)
throw Error(this.parent.errorMessage())
return (format := XL.IFormat(format), ret)
}
writeStr(row, col, value, format := 0) => DllCall('libxl\xlSheetWriteStr', 'ptr', this, 'int', row, 'int', col, 'str', value, 'ptr', format, 'cdecl int')
readRichStr(row, col, &format := 0) {
ret := XL.IRichString(DllCall('libxl\xlSheetReadRichStr', 'ptr', this, 'int', row, 'int', col, 'ptr*', &format := 0, 'cdecl ptr'))
if (!format)
throw Error(this.parent.errorMessage())
return (format := XL.IFormat(format), ret)
}
writeRichStr(row, col, richString, format := 0) => DllCall('libxl\xlSheetWriteRichStr', 'ptr', this, 'int', row, 'int', col, 'ptr', richString, 'ptr', format, 'cdecl int')
readNum(row, col, &format := 0) {
ret := DllCall('libxl\xlSheetReadNum', 'ptr', this, 'int', row, 'int', col, 'ptr*', &format := 0, 'cdecl double')
if (!format)
throw Error(this.parent.errorMessage())
return (format := XL.IFormat(format), ret)
}
writeNum(row, col, value, format := 0) => DllCall('libxl\xlSheetWriteNum', 'ptr', this, 'int', row, 'int', col, 'double', value, 'ptr', format, 'cdecl int')
readBool(row, col, &format := 0) {
ret := DllCall('libxl\xlSheetReadBool', 'ptr', this, 'int', row, 'int', col, 'ptr*', &format := 0, 'cdecl int')
if (!format)
throw Error(this.parent.errorMessage())
return (format := XL.IFormat(format), ret)
}
writeBool(row, col, value, format := 0) => DllCall('libxl\xlSheetWriteBool', 'ptr', this, 'int', row, 'int', col, 'int', value, 'ptr', format, 'cdecl int')
readBlank(row, col, &format := 0) {
ret := DllCall('libxl\xlSheetReadBlank', 'ptr', this, 'int', row, 'int', col, 'ptr*', &format := 0, 'cdecl int')
if (!format)
throw Error(this.parent.errorMessage())
return (format := XL.IFormat(format), ret)
}
writeBlank(row, col, format) => DllCall('libxl\xlSheetWriteBlank', 'ptr', this, 'int', row, 'int', col, 'ptr', format, 'cdecl int')
readFormula(row, col, &format := unset) {
ret := DllCall('libxl\xlSheetReadFormula', 'ptr', this, 'int', row, 'int', col, 'ptr*', &format := 0, 'cdecl str')
if (!format)
throw Error(this.parent.errorMessage())
return (format := XL.IFormat(format), ret)
}
writeFormula(row, col, expr, format := 0) => DllCall('libxl\xlSheetWriteFormula', 'ptr', this, 'int', row, 'int', col, 'str', expr, 'ptr', format, 'cdecl int')
writeFormulaNum(row, col, expr, value, format := 0) => DllCall('libxl\xlSheetWriteFormulaNum', 'ptr', this, 'int', row, 'int', col, 'str', expr, 'double', value, 'ptr', format, 'cdecl int')
writeFormulaStr(row, col, expr, value, format := 0) => DllCall('libxl\xlSheetWriteFormulaStr', 'ptr', this, 'int', row, 'int', col, 'str', expr, 'str', value, 'ptr', format, 'cdecl int')
writeFormulaBool(row, col, expr, value, format := 0) => DllCall('libxl\xlSheetWriteFormulaBool', 'ptr', this, 'int', row, 'int', col, 'str', expr, 'int', value, 'ptr', format, 'cdecl int')
readComment(row, col) => DllCall('libxl\xlSheetReadComment', 'ptr', this, 'int', row, 'int', col, 'cdecl str')
writeComment(row, col, value, author := 0, width := 129, height := 75) => DllCall('libxl\xlSheetWriteComment', 'ptr', this, 'int', row, 'int', col, 'str', value, 'str', author, 'int', width, 'int', height, 'cdecl')
removeComment(row, col) => DllCall('libxl\xlSheetRemoveComment', 'ptr', this, 'int', row, 'int', col, 'cdecl')
isDate(row, col) => DllCall('libxl\xlSheetIsDate', 'ptr', this, 'int', row, 'int', col, 'cdecl int')
isRichStr(row, col) => DllCall('libxl\xlSheetIsRichStr', 'ptr', this, 'int', row, 'int', col, 'cdecl int')
readError(row, col) => DllCall('libxl\xlSheetReadError', 'ptr', this, 'int', row, 'int', col, 'cdecl int')
writeError(row, col, ErrorType, format := 0) => DllCall('libxl\xlSheetWriteError', 'ptr', this, 'int', row, 'int', col, 'int', ErrorType, 'ptr', format, 'cdecl')
colWidth(col) => DllCall('libxl\xlSheetColWidth', 'ptr', this, 'int', col, 'cdecl double')
rowHeight(row) => DllCall('libxl\xlSheetRowHeight', 'ptr', this, 'int', row, 'cdecl double')
colWidthPx(col) => DllCall('libxl\xlSheetColWidthPx', 'ptr', this, 'int', col, 'cdecl int')
rowHeightPx(row) => DllCall('libxl\xlSheetRowHeightPx', 'ptr', this, 'int', row, 'cdecl int')
setCol(colFirst, colLast, width, format := 0, hidden := false) => DllCall('libxl\xlSheetSetCol', 'ptr', this, 'int', colFirst, 'int', colLast, 'double', width, 'ptr', format, 'int', hidden, 'cdecl int')
setRow(row, height, format := 0, hidden := false) => DllCall('libxl\xlSheetSetRow', 'ptr', this, 'int', row, 'double', height, 'ptr', format, 'int', hidden, 'cdecl int')
rowHidden(row) => DllCall('libxl\xlSheetRowHidden', 'ptr', this, 'int', row, 'cdecl int')
setRowHidden(row, hidden) => DllCall('libxl\xlSheetSetRowHidden', 'ptr', this, 'int', row, 'int', hidden, 'cdecl int')
colHidden(col) => DllCall('libxl\xlSheetColHidden', 'ptr', this, 'int', col, 'cdecl int')
setColHidden(col, hidden) => DllCall('libxl\xlSheetSetColHidden', 'ptr', this, 'int', col, 'int', hidden, 'cdecl int')
getMerge(row, col, &rowFirst := 0, &rowLast := 0, &colFirst := 0, &colLast := 0) => DllCall('libxl\xlSheetGetMerge', 'ptr', this, 'int', row, 'int', col, 'int*', &rowFirst := 0, 'int*', &rowLast := 0, 'int*', &colFirst := 0, 'int*', &colLast := 0, 'cdecl int')
setMerge(rowFirst, rowLast, colFirst, colLast) => DllCall('libxl\xlSheetSetMerge', 'ptr', this, 'int', rowFirst, 'int', rowLast, 'int', colFirst, 'int', colLast, 'cdecl int')
delMerge(row, col) => DllCall('libxl\xlSheetDelMerge', 'ptr', this, 'int', row, 'int', col, 'cdecl int')
mergeSize() => DllCall('libxl\xlSheetMergeSize', 'ptr', this, 'cdecl int')
merge(index, &rowFirst, &rowLast, &colFirst, &colLast) => DllCall('libxl\xlSheetMerge', 'ptr', this, 'int', index, 'int*', &rowFirst := 0, 'int*', &rowLast := 0, 'int*', &colFirst := 0, 'int*', &colLast := 0, 'cdecl int')
delMergeByIndex(index) => DllCall('libxl\xlSheetDelMergeByIndex', 'ptr', this, 'int', index, 'cdecl int')
pictureSize() => DllCall('libxl\xlSheetPictureSize', 'ptr', this, 'cdecl int')
getPicture(index, &rowTop := 0, &colLeft := 0, &rowBottom := 0, &colRight := 0, &width := 0, &height := 0, &offset_x := 0, &offset_y := 0) => DllCall('libxl\xlSheetGetPicture', 'ptr', this, 'int', index, 'int*', &rowTop := 0, 'int*', &colLeft := 0, 'int*', &rowBottom := 0, 'int*', &colRight := 0, 'int*', &width := 0, 'int*', &height := 0, 'int*', &offset_x := 0, 'int*', &offset_y := 0, 'cdecl int')
removePictureByIndex(index) => DllCall('libxl\xlSheetRemovePictureByIndex', 'ptr', this, 'int', index, 'cdecl int')
setPicture(row, col, pictureId, scale := 1.0, offset_x := 0, offset_y := 0, pos := 0) => DllCall('libxl\xlSheetSetPicture', 'ptr', this, 'int', row, 'int', col, 'int', pictureId, 'double', scale, 'int', offset_x, 'int', offset_y, 'int', pos, 'cdecl')
setPicture2(row, col, pictureId, width := -1, height := -1, offset_x := 0, offset_y := 0, pos := 0) => DllCall('libxl\xlSheetSetPicture2', 'ptr', this, 'int', row, 'int', col, 'int', pictureId, 'int', width, 'int', height, 'int', offset_x, 'int', offset_y, 'int', pos, 'cdecl')
removePicture(row, col) => DllCall('libxl\xlSheetRemovePicture', 'ptr', this, 'int', row, 'int', col, 'cdecl int')
getHorPageBreak(index) => DllCall('libxl\xlSheetGetHorPageBreak', 'ptr', this, 'int', index, 'cdecl int')
getHorPageBreakSize() => DllCall('libxl\xlSheetGetHorPageBreakSize', 'ptr', this, 'cdecl int')
getVerPageBreak(index) => DllCall('libxl\xlSheetGetVerPageBreak', 'ptr', this, 'int', index, 'cdecl int')
getVerPageBreakSize() => DllCall('libxl\xlSheetGetVerPageBreakSize', 'ptr', this, 'cdecl int')
setHorPageBreak(row, pageBreak := true) => DllCall('libxl\xlSheetSetHorPageBreak', 'ptr', this, 'int', row, 'int', pageBreak, 'cdecl int')
setVerPageBreak(col, pageBreak := true) => DllCall('libxl\xlSheetSetVerPageBreak', 'ptr', this, 'int', col, 'int', pageBreak, 'cdecl int')
split(row, col) => DllCall('libxl\xlSheetSplit', 'ptr', this, 'int', row, 'int', col, 'cdecl')
splitInfo(&row, &col) => DllCall('libxl\xlSheetSplitInfo', 'ptr', this, 'int*', &row := 0, 'int*', &col := 0, 'cdecl int')
groupRows(rowFirst, rowLast, collapsed := true) => DllCall('libxl\xlSheetGroupRows', 'ptr', this, 'int', rowFirst, 'int', rowLast, 'int', collapsed, 'cdecl int')
groupCols(colFirst, colLast, collapsed := true) => DllCall('libxl\xlSheetGroupCols', 'ptr', this, 'int', colFirst, 'int', colLast, 'int', collapsed, 'cdecl int')
groupSummaryBelow() => DllCall('libxl\xlSheetGroupSummaryBelow', 'ptr', this, 'cdecl int')
setGroupSummaryBelow(below) => DllCall('libxl\xlSheetSetGroupSummaryBelow', 'ptr', this, 'int', below, 'cdecl')
groupSummaryRight() => DllCall('libxl\xlSheetGroupSummaryRight', 'ptr', this, 'cdecl int')
setGroupSummaryRight(right) => DllCall('libxl\xlSheetSetGroupSummaryRight', 'ptr', this, 'int', right, 'cdecl')
clear(rowFirst := 0, rowLast := 1048575, colFirst := 0, colLast := 16383) => DllCall('libxl\xlSheetClear', 'ptr', this, 'int', rowFirst, 'int', rowLast, 'int', colFirst, 'int', colLast, 'cdecl int')
insertCol(colFirst, colLast, updateNamedRanges := true) => DllCall('libxl\xlSheetInsertCol', 'ptr', this, 'int', colFirst, 'int', colLast, 'cdecl int')
insertRow(rowFirst, rowLast, updateNamedRanges := true) => DllCall('libxl\xlSheetInsertRow', 'ptr', this, 'int', rowFirst, 'int', rowLast, 'cdecl int')
removeCol(colFirst, colLast, updateNamedRanges := true) => DllCall('libxl\xlSheetRemoveCol', 'ptr', this, 'int', colFirst, 'int', colLast, 'cdecl int')
removeRow(rowFirst, rowLast, updateNamedRanges := true) => DllCall('libxl\xlSheetRemoveRow', 'ptr', this, 'int', rowFirst, 'int', rowLast, 'cdecl int')
insertColAndKeepRanges(colFirst, colLast) => DllCall('libxl\xlSheetInsertColAndKeepRanges', 'ptr', this, 'int', colFirst, 'int', colLast, 'cdecl int')
insertRowAndKeepRanges(rowFirst, rowLast) => DllCall('libxl\xlSheetInsertRowAndKeepRanges', 'ptr', this, 'int', rowFirst, 'int', rowLast, 'cdecl int')
removeColAndKeepRanges(colFirst, colLast) => DllCall('libxl\xlSheetRemoveColAndKeepRanges', 'ptr', this, 'int', colFirst, 'int', colLast, 'cdecl int')
removeRowAndKeepRanges(rowFirst, rowLast) => DllCall('libxl\xlSheetRemoveRowAndKeepRanges', 'ptr', this, 'int', rowFirst, 'int', rowLast, 'cdecl int')
copyCell(rowSrc, colSrc, rowDst, colDst) => DllCall('libxl\xlSheetCopyCell', 'ptr', this, 'int', rowSrc, 'int', colSrc, 'int', rowDst, 'int', colDst, 'cdecl int')
firstRow() => DllCall('libxl\xlSheetFirstRow', 'ptr', this, 'cdecl int')
lastRow() => DllCall('libxl\xlSheetLastRow', 'ptr', this, 'cdecl int')
firstCol() => DllCall('libxl\xlSheetFirstCol', 'ptr', this, 'cdecl int')
lastCol() => DllCall('libxl\xlSheetLastCol', 'ptr', this, 'cdecl int')
firstFilledRow() => DllCall('libxl\xlSheetFirstFilledRow', 'ptr', this, 'cdecl int')
lastFilledRow() => DllCall('libxl\xlSheetLastFilledRow', 'ptr', this, 'cdecl int')
firstFilledCol() => DllCall('libxl\xlSheetFirstFilledCol', 'ptr', this, 'cdecl int')
lastFilledCol() => DllCall('libxl\xlSheetLastFilledCol', 'ptr', this, 'cdecl int')
displayGridlines() => DllCall('libxl\xlSheetDisplayGridlines', 'ptr', this, 'cdecl int')
setDisplayGridlines(show := true) => DllCall('libxl\xlSheetSetDisplayGridlines', 'ptr', this, 'int', show, 'cdecl')
printGridlines() => DllCall('libxl\xlSheetPrintGridlines', 'ptr', this, 'cdecl int')
setPrintGridlines(print := true) => DllCall('libxl\xlSheetSetPrintGridlines', 'ptr', this, 'int', print, 'cdecl')
zoom() => DllCall('libxl\xlSheetZoom', 'ptr', this, 'cdecl int')
setZoom(zoom) => DllCall('libxl\xlSheetSetZoom', 'ptr', this, 'int', zoom, 'cdecl')
printZoom() => DllCall('libxl\xlSheetPrintZoom', 'ptr', this, 'cdecl int')
setPrintZoom(zoom) => DllCall('libxl\xlSheetSetPrintZoom', 'ptr', this, 'int', zoom, 'cdecl')
getPrintFit(&wPages, &hPages) => DllCall('libxl\xlSheetGetPrintFit', 'ptr', this, 'int*', &wPages := 0, 'int*', &hPages := 0, 'cdecl int')
setPrintFit(wPages := 1, hPages := 1) => DllCall('libxl\xlSheetSetPrintFit', 'ptr', this, 'int', wPages, 'int', hPages, 'cdecl')
landscape() => DllCall('libxl\xlSheetLandscape', 'ptr', this, 'cdecl int')
setLandscape(landscape := true) => DllCall('libxl\xlSheetSetLandscape', 'ptr', this, 'int', landscape, 'cdecl')
paper() => DllCall('libxl\xlSheetPaper', 'ptr', this, 'cdecl int')
setPaper(Paper := 0) => DllCall('libxl\xlSheetSetPaper', 'ptr', this, 'int', paper, 'cdecl')
header() => DllCall('libxl\xlSheetHeader', 'ptr', this, 'cdecl str')
setHeader(header, margin := 0.5) => DllCall('libxl\xlSheetSetHeader', 'ptr', this, 'str', header, 'double', margin, 'cdecl int')
headerMargin() => DllCall('libxl\xlSheetHeaderMargin', 'ptr', this, 'cdecl double')
footer() => DllCall('libxl\xlSheetFooter', 'ptr', this, 'cdecl str')
setFooter(footer, margin := 0.5) => DllCall('libxl\xlSheetSetFooter', 'ptr', this, 'str', footer, 'double', margin, 'cdecl int')
footerMargin() => DllCall('libxl\xlSheetFooterMargin', 'ptr', this, 'cdecl double')
hCenter() => DllCall('libxl\xlSheetHCenter', 'ptr', this, 'cdecl int')
setHCenter(hCenter := true) => DllCall('libxl\xlSheetSetHCenter', 'ptr', this, 'int', hCenter, 'cdecl')
vCenter() => DllCall('libxl\xlSheetVCenter', 'ptr', this, 'cdecl int')
setVCenter(vCenter := true) => DllCall('libxl\xlSheetSetVCenter', 'ptr', this, 'int', vCenter, 'cdecl')
marginLeft() => DllCall('libxl\xlSheetMarginLeft', 'ptr', this, 'cdecl double')
setMarginLeft(margin) => DllCall('libxl\xlSheetSetMarginLeft', 'ptr', this, 'double', margin, 'cdecl')
marginRight() => DllCall('libxl\xlSheetMarginRight', 'ptr', this, 'cdecl double')
setMarginRight(margin) => DllCall('libxl\xlSheetSetMarginRight', 'ptr', this, 'double', margin, 'cdecl')
marginTop() => DllCall('libxl\xlSheetMarginTop', 'ptr', this, 'cdecl double')
setMarginTop(margin) => DllCall('libxl\xlSheetSetMarginTop', 'ptr', this, 'double', margin, 'cdecl')
marginBottom() => DllCall('libxl\xlSheetMarginBottom', 'ptr', this, 'cdecl double')
setMarginBottom(margin) => DllCall('libxl\xlSheetSetMarginBottom', 'ptr', this, 'double', margin, 'cdecl')
printRowCol() => DllCall('libxl\xlSheetPrintRowCol', 'ptr', this, 'cdecl int')
setPrintRowCol(print := true) => DllCall('libxl\xlSheetSetPrintRowCol', 'ptr', this, 'int', print, 'cdecl')
printRepeatRows(&rowFirst, &rowLast) => DllCall('libxl\xlSheetPrintRepeatRows', 'ptr', this, 'int*', &rowFirst := 0, 'int*', &rowLast := 0, 'cdecl int')
setPrintRepeatRows(rowFirst, rowLast) => DllCall('libxl\xlSheetSetPrintRepeatRows', 'ptr', this, 'int', rowFirst, 'int', rowLast, 'cdecl')
printRepeatCols(&colFirst, &colLast) => DllCall('libxl\xlSheetPrintRepeatCols', 'ptr', this, 'int*', &colFirst := 0, 'int*', &colLast := 0, 'cdecl int')
setPrintRepeatCols(colFirst, colLast) => DllCall('libxl\xlSheetSetPrintRepeatCols', 'ptr', this, 'int', colFirst, 'int', colLast, 'cdecl')
printArea(&rowFirst, &rowLast, &colFirst, &colLast) => DllCall('libxl\xlSheetPrintArea', 'ptr', this, 'int*', &rowFirst := 0, 'int*', &rowLast := 0, 'int*', &colFirst := 0, 'int*', &colLast := 0, 'cdecl int')
setPrintArea(rowFirst, rowLast, colFirst, colLast) => DllCall('libxl\xlSheetSetPrintArea', 'ptr', this, 'int', rowFirst, 'int', rowLast, 'int', colFirst, 'int', colLast, 'cdecl')
clearPrintRepeats() => DllCall('libxl\xlSheetClearPrintRepeats', 'ptr', this, 'cdecl')
clearPrintArea() => DllCall('libxl\xlSheetClearPrintArea', 'ptr', this, 'cdecl')
getNamedRange(name, &rowFirst, &rowLast, &colFirst, &colLast, scopeId := -2, &hidden := 0) => DllCall('libxl\xlSheetGetNamedRange', 'ptr', this, 'str', name, 'int*', &rowFirst := 0, 'int*', &rowLast := 0, 'int*', &colFirst := 0, 'int*', &colLast := 0, 'int', scopeId, 'int*', &hidden := 0, 'cdecl int')
setNamedRange(name, rowFirst, rowLast, colFirst, colLast, scopeId := -2, hidden := false) => DllCall('libxl\xlSheetSetNamedRange', 'ptr', this, 'str', name, 'int', rowFirst, 'int', rowLast, 'int', colFirst, 'int', colLast, 'int', scopeId, 'cdecl int')
delNamedRange(name, scopeId := -2) => DllCall('libxl\xlSheetDelNamedRange', 'ptr', this, 'str', name, 'int', scopeId, 'cdecl int')
namedRangeSize() => DllCall('libxl\xlSheetNamedRangeSize', 'ptr', this, 'cdecl int')
namedRange(index, &rowFirst, &rowLast, &colFirst, &colLast, &scopeId := 0, &hidden := 0) => DllCall('libxl\xlSheetNamedRange', 'ptr', this, 'int', index, 'int*', &rowFirst := 0, 'int*', &rowLast := 0, 'int*', &colFirst := 0, 'int*', &colLast := 0, 'int*', &scopeId := 0, 'int*', &hidden := 0, 'cdecl str')
tableSize() => DllCall('libxl\xlSheetTableSize', 'ptr', this, 'cdecl int')
table(index, &rowFirst, &rowLast, &colFirst, &colLast, &headerRowCount, &totalsRowCount) => DllCall('libxl\xlSheetTable', 'ptr', this, 'int', index, 'int*', &rowFirst := 0, 'int*', &rowLast := 0, 'int*', &colFirst := 0, 'int*', &colLast := 0, 'int*', &headerRowCount := 0, 'int*', &totalsRowCount := 0, 'cdecl str')
hyperlinkSize() => DllCall('libxl\xlSheetHyperlinkSize', 'ptr', this, 'cdecl int')
hyperlink(index, &rowFirst, &rowLast, &colFirst, &colLast) => DllCall('libxl\xlSheetHyperlink', 'ptr', this, 'int', index, 'int*', &rowFirst := 0, 'int*', &rowLast := 0, 'int*', &colFirst := 0, 'int*', &colLast := 0, 'cdecl str')
delHyperlink(index) => DllCall('libxl\xlSheetDelHyperlink', 'ptr', this, 'int', index, 'cdecl int')
addHyperlink(hyperlink, rowFirst, rowLast, colFirst, colLast) => DllCall('libxl\xlSheetAddHyperlink', 'ptr', this, 'str', hyperlink, 'int', rowFirst, 'int', rowLast, 'int', colFirst, 'int', colLast, 'cdecl')
autoFilter() => XL.IAutoFilter(DllCall('libxl\xlSheetAutoFilter', 'ptr', this, 'cdecl ptr'))
applyFilter() => DllCall('libxl\xlSheetApplyFilter', 'ptr', this, 'cdecl')
removeFilter() => DllCall('libxl\xlSheetRemoveFilter', 'ptr', this, 'cdecl')
name() => DllCall('libxl\xlSheetName', 'ptr', this, 'cdecl str')
setName(name) => DllCall('libxl\xlSheetSetName', 'ptr', this, 'str', name, 'cdecl')
protect() => DllCall('libxl\xlSheetProtect', 'ptr', this, 'cdecl int')
setProtect(protect := true, password := 0, enhancedProtection := -1) => DllCall('libxl\xlSheetSetProtectEx', 'ptr', this, 'int', protect, 'ptr', Type(password) = 'String' ? StrPtr(password) : password, 'int', enhancedProtection, 'cdecl')
hidden() => DllCall('libxl\xlSheetHidden', 'ptr', this, 'cdecl int')
setHidden(SheetState := 1) => DllCall('libxl\xlSheetSetHidden', 'ptr', this, 'int', SheetState, 'cdecl int')
getTopLeftView(&row, &col) => DllCall('libxl\xlSheetGetTopLeftView', 'ptr', this, 'int*', &row := 0, 'int*', &col := 0, 'cdecl')
setTopLeftView(row, col) => DllCall('libxl\xlSheetSetTopLeftView', 'ptr', this, 'int', row, 'int', col, 'cdecl')
rightToLeft() => DllCall('libxl\xlSheetRightToLeft', 'ptr', this, 'cdecl int')
setRightToLeft(rightToLeft := true) => DllCall('libxl\xlSheetSetRightToLeft', 'ptr', this, 'int', rightToLeft, 'cdecl')
setAutoFitArea(rowFirst := 0, colFirst := 0, rowLast := -1, colLast := -1) => DllCall('libxl\xlSheetSetAutoFitArea', 'ptr', this, 'int', rowFirst, 'int', colFirst, 'int', rowLast, 'int', colLast, 'cdecl')
addrToRowCol(addr, &row, &col, &rowRelative := 0, &colRelative := 0) => DllCall('libxl\xlSheetAddrToRowCol', 'ptr', this, 'str', StrUpper(addr), 'int*', &row := 0, 'int*', &col := 0, 'int*', &rowRelative := 0, 'int*', &colRelative := 0, 'cdecl')
rowColToAddr(row, col, rowRelative := true, colRelative := true) => DllCall('libxl\xlSheetRowColToAddr', 'ptr', this, 'int', row, 'int', col, 'int', rowRelative, 'int', colRelative, 'cdecl str')
setTabColor(Color) => DllCall('libxl\xlSheetSetTabColor', 'ptr', this, 'int', Color, 'cdecl')
setTabRGBColor(red, green, blue) => DllCall('libxl\xlSheetSetTabRgbColor', 'ptr', this, 'int', red, 'int', green, 'int', blue, 'cdecl')
addIgnoredError(rowFirst, colFirst, rowLast, colLast, IgnoredError) => DllCall('libxl\xlSheetAddIgnoredError', 'ptr', this, 'int', rowFirst, 'int', colFirst, 'int', rowLast, 'int', colLast, 'int', IgnoredError, 'cdecl int')
addDataValidation(type, op, rowFirst, rowLast, colFirst, colLast, value1, value2) => DllCall('libxl\xlSheetAddDataValidation', 'ptr', this, 'int', type, 'int', op, 'int', rowFirst, 'int', rowLast, 'int', colFirst, 'int', colLast, 'str', value1, 'str', value2, 'cdecl')
addDataValidationEx(type, op, rowFirst, rowLast, colFirst, colLast, value1, value2, allowBlank := true, hideDropDown := false, showInputMessage := true, showErrorMessage := true, promptTitle := 0, prompt := 0, errorTitle := 0, error := 0, errorStyle := 0) => DllCall('libxl\xlSheetAddDataValidationEx', 'ptr', this, 'int', type, 'int', op, 'int', rowFirst, 'int', rowLast, 'int', colFirst, 'int', colLast, 'str', value1, 'str', value2, 'int', allowBlank, 'int', hideDropDown, 'int', showInputMessage, 'int', showErrorMessage, 'str', promptTitle, 'str', prompt, 'str', errorTitle, 'str', error, 'int', errorStyle, 'cdecl')
addDataValidationDouble(type, op, rowFirst, rowLast, colFirst, colLast, value1, value2) => DllCall('libxl\xlSheetAddDataValidationDouble', 'ptr', this, 'int', type, 'int', op, 'int', rowFirst, 'int', rowLast, 'int', colFirst, 'int', colLast, 'double', value1, 'double', value2, 'cdecl')
addDataValidationDoubleEx(type, op, rowFirst, rowLast, colFirst, colLast, value1, value2, allowBlank := true, hideDropDown := false, showInputMessage := true, showErrorMessage := true, promptTitle := 0, prompt := 0, errorTitle := 0, error := 0, errorStyle := 0) => DllCall('libxl\xlSheetAddDataValidationDoubleEx', 'ptr', this, 'int', type, 'int', op, 'int', rowFirst, 'int', rowLast, 'int', colFirst, 'int', colLast, 'double', value1, 'double', value2, 'int', allowBlank, 'int', hideDropDown, 'int', showInputMessage, 'int', showErrorMessage, 'str', promptTitle, 'str', prompt, 'str', errorTitle, 'str', error, 'int', errorStyle, 'cdecl')
removeDataValidations() => DllCall('libxl\xlSheetRemoveDataValidations', 'ptr', this, 'cdecl')
__Delete() => (this.parent := '')
__Item[row, col := ''] {
get => (IsNumber(row) ? '' : this.addrToRowCol(row, &row, &col), XL.ISheet.ICell(row, col, this))
set {
if (ret := format := 0, bool := formula := '', !IsNumber(row))
this.addrToRowCol(row, &row, &col)
rechecktype:
switch Type(value) {
case 'Object':
val := value, value := ''
for k in val.OwnProps()
switch StrLower(k) {
case 'format':
format := val.format
case 'bool':
value := val.bool, bool := true
case 'exp', 'expr', 'formula':
formula := val.%k%
case 'int', 'integer':
value := Integer(val.%k%)
case 'num', 'float', 'number', 'double':
value := Float(val.%k%)
default:
value := val.%k%
}
if (formula != '') {
if (bool)
ret := this.writeFormulaBool(row, col, formula, !!value, format)
else if (value = '')
ret := this.writeFormula(row, col, formula, format)
else if ('String' = Type(value))
ret := this.writeFormulaStr(row, col, formula, value, format)
else ret := this.writeFormulaNum(row, col, formula, value, format)
} else if (bool)
ret := this.writeBool(row, col, !!value, format)
else goto rechecktype
case 'String':
ret := this.writeStr(row, col, value, format)
case 'Integer', 'Float':
ret := this.writeNum(row, col, value, format)
case 'XL.IRichString':
ret := this.writeRichStr(row, col, value, format)
default:
throw Error('Wrong parameter type')
}
if (!ret && (msg := this.parent.errorMessage()) != 'ok')
throw Error(msg)
}
}
class ICell {
__New(row, col, parent) {
if (parent.cellType(row, col) = 0)
throw Error('Cell does not exist', -1)
this.row := row, this.col := col, this.parent := parent
}
content {
get {
format := 0, ret := {value: '', type: '', format: 0}, row := this.row, col := this.col
switch this.parent.cellType(row, col) {
case 0: ; EMPTY
return ''
case 1: ; NUMBER, DATE
if (this.parent.isDate(row, col)) {
year := month := day := hour := min := sec := msec := 0, this.parent.dateUnpack(ret.value, &year, &month, &day, &hour, &min, &sec, &msec)
ret := {year: year, month: month, day: day, hour: hour, min: min, sec: sec, msec: msec}
ret.value := this.parent.readNum(row, col, &format), ret.type := 'DATE'
} else if (this.parent.isFormula(row, col)) {
ret.formula := this.parent.readFormula(row, col, &format), ret.type := 'FORMULA'
try ret.value := this.parent.readNum(row, col)
} else ret.type := 'NUMBER', ret.value := this.parent.readNum(row, col, &format)
ret.format := format
case 2: ; STRING, FORMULA, RICHSTRING
if (this.parent.isRichStr(row, col))
ret.richstr := this.parent.readRichStr(row, col, &format), ret.type := 'RICHSTRING', ret.value := this.parent.readStr(row, col)
else if (this.parent.isFormula(row, col)) {
ret.formula := this.parent.readFormula(row, col, &format), ret.type := 'FORMULA'
try ret.value := this.parent.readStr(row, col)
} else ret.type := 'STRING', ret.value := this.parent.readStr(row, col, &format)
ret.format := format
case 3: ; BOOLEAN
ret.value := this.parent.readBool(row, col, &format), ret.format := format, ret.type := 'BOOLEAN'
case 4: ; BLANK
this.parent.readBlank(row, col, &format), ret.format := format, ret.type := 'BLANK'
default: ;ERROR
ret.type := 'ERROR'
switch ret.errcode := this.parent.readError(row, col) {
case 0:
ret.value := '#NULL!'
case 0x7:
ret.value := '#DIV/0!'
case 0xF:
ret.value := '#VALUE!'
case 0x17:
ret.value := '#REF!'
case 0x1D:
ret.value := '#NAME?'
case 0x24:
ret.value := '#NUM!'
case 0x2A:
ret.value := '#N/A'
default:
ret.value := 'no error'
}
}
return ret
}
}
value {
get => this.content.value
set => (this.parent[this.row, this.col] := {value: value, format: this.format})
}
format {
get => this.parent.cellFormat(this.row, this.col)
set => this.parent.setCellFormat(this.row, this.col, value)
}
comment {
get => this.parent.readComment(this.row, this.col)
set {
if (value = '')
return this.parent.removeComment(this.row, this.col)
author := height := width := ''
for k in ['author', 'width', 'height', 'value']
%k% := value.HasOwnProp(k) ? value.%k% : ''
return this.parent.writeComment(this.row, this.col, value, author, height || 129, width || 75)
}
}
width {
get => this.parent.colWidth(this.col)
set => this.parent.setCol(this.col, this.col, value, this.format, this.parent.colHidden(this.col))
}
height {
get => this.parent.rowHeight(this.row)
set => this.parent.setRow(this.row, this.row, value, this.format, this.parent.rowHidden(this.row))
}
hidden => this.parent.rowHidden(this.row) || this.parent.colHidden(this.col)
copy(rowDst, colDst) => this.parent.copyCell(this.row, this.col, rowDst, colDst)
}
}
}