writeexcel 0.5.0 → 0.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/.gitattributes +1 -1
- data/.gitignore +24 -24
- data/README.rdoc +34 -55
- data/VERSION +1 -1
- data/charts/chartex.rb +316 -316
- data/charts/demo1.rb +46 -46
- data/charts/demo2.rb +65 -65
- data/charts/demo3.rb +117 -117
- data/charts/demo4.rb +119 -119
- data/charts/demo5.rb +48 -48
- data/examples/a_simple.rb +43 -43
- data/examples/autofilter.rb +265 -265
- data/examples/bigfile.rb +30 -30
- data/examples/chart_area.rb +121 -121
- data/examples/chart_bar.rb +120 -120
- data/examples/chart_column.rb +120 -120
- data/examples/chart_line.rb +120 -120
- data/examples/chart_pie.rb +108 -108
- data/examples/chart_scatter.rb +121 -121
- data/examples/chart_stock.rb +148 -148
- data/examples/chess.rb +142 -142
- data/examples/colors.rb +129 -129
- data/examples/comments1.rb +27 -27
- data/examples/comments2.rb +352 -352
- data/examples/copyformat.rb +52 -52
- data/examples/data_validate.rb +279 -279
- data/examples/date_time.rb +87 -87
- data/examples/defined_name.rb +32 -32
- data/examples/demo.rb +124 -124
- data/examples/diag_border.rb +36 -36
- data/examples/formats.rb +490 -490
- data/examples/formula_result.rb +30 -30
- data/examples/header.rb +137 -137
- data/examples/hide_sheet.rb +29 -29
- data/examples/hyperlink.rb +43 -43
- data/examples/images.rb +63 -63
- data/examples/indent.rb +31 -31
- data/examples/merge1.rb +40 -40
- data/examples/merge2.rb +45 -45
- data/examples/merge3.rb +66 -66
- data/examples/merge4.rb +83 -83
- data/examples/merge5.rb +80 -80
- data/examples/merge6.rb +67 -67
- data/examples/outline.rb +255 -255
- data/examples/outline_collapsed.rb +209 -209
- data/examples/panes.rb +113 -113
- data/examples/properties.rb +34 -34
- data/examples/properties_jp.rb +33 -33
- data/examples/protection.rb +47 -47
- data/examples/regions.rb +53 -53
- data/examples/repeat.rb +43 -43
- data/examples/right_to_left.rb +27 -27
- data/examples/row_wrap.rb +53 -53
- data/examples/stats.rb +74 -74
- data/examples/stocks.rb +81 -81
- data/examples/tab_colors.rb +31 -31
- data/examples/utf8.rb +15 -15
- data/examples/write_arrays.rb +83 -83
- data/lib/writeexcel/biffwriter.rb +232 -232
- data/lib/writeexcel/caller_info.rb +12 -12
- data/lib/writeexcel/chart.rb +2190 -2177
- data/lib/writeexcel/charts/area.rb +154 -154
- data/lib/writeexcel/charts/bar.rb +177 -177
- data/lib/writeexcel/charts/column.rb +156 -156
- data/lib/writeexcel/charts/external.rb +66 -66
- data/lib/writeexcel/charts/line.rb +154 -154
- data/lib/writeexcel/charts/pie.rb +169 -169
- data/lib/writeexcel/charts/scatter.rb +192 -192
- data/lib/writeexcel/charts/stock.rb +213 -213
- data/lib/writeexcel/colors.rb +64 -64
- data/lib/writeexcel/compatibility.rb +0 -255
- data/lib/writeexcel/debug_info.rb +37 -33
- data/lib/writeexcel/excelformulaparser.rb +587 -587
- data/lib/writeexcel/format.rb +13 -4
- data/lib/writeexcel/formula.rb +26 -9
- data/lib/writeexcel/helper.rb +68 -64
- data/lib/writeexcel/olewriter.rb +311 -311
- data/lib/writeexcel/properties.rb +242 -240
- data/lib/writeexcel/storage_lite.rb +984 -978
- data/lib/writeexcel/workbook.rb +3210 -3192
- data/lib/writeexcel/worksheet.rb +143 -51
- data/lib/writeexcel/write_file.rb +44 -40
- data/lib/writeexcel.rb +1159 -1159
- data/test/helper.rb +31 -28
- data/test/perl_output/README +31 -31
- data/test/test_00_IEEE_double.rb +13 -13
- data/test/test_01_add_worksheet.rb +10 -10
- data/test/test_02_merge_formats.rb +53 -53
- data/test/test_04_dimensions.rb +392 -392
- data/test/test_05_rows.rb +179 -179
- data/test/test_06_extsst.rb +77 -77
- data/test/test_11_date_time.rb +479 -479
- data/test/test_12_date_only.rb +501 -501
- data/test/test_13_date_seconds.rb +481 -481
- data/test/test_21_escher.rb +637 -637
- data/test/test_22_mso_drawing_group.rb +745 -745
- data/test/test_23_note.rb +73 -73
- data/test/test_24_txo.rb +75 -75
- data/test/test_25_position_object.rb +84 -84
- data/test/test_26_autofilter.rb +314 -314
- data/test/test_27_autofilter.rb +131 -131
- data/test/test_28_autofilter.rb +161 -161
- data/test/test_29_process_jpg.rb +683 -683
- data/test/test_30_validation_dval.rb +77 -77
- data/test/test_31_validation_dv_strings.rb +126 -126
- data/test/test_32_validation_dv_formula.rb +206 -206
- data/test/test_40_property_types.rb +188 -188
- data/test/test_41_properties.rb +235 -235
- data/test/test_42_set_properties.rb +437 -437
- data/test/test_50_name_stored.rb +299 -299
- data/test/test_51_name_print_area.rb +357 -357
- data/test/test_52_name_print_titles.rb +454 -454
- data/test/test_53_autofilter.rb +203 -203
- data/test/test_60_chart_generic.rb +578 -578
- data/test/test_61_chart_subclasses.rb +95 -95
- data/test/test_62_chart_formats.rb +272 -272
- data/test/test_63_chart_area_formats.rb +649 -649
- data/test/test_biff.rb +75 -75
- data/test/test_compatibility.rb +12 -627
- data/test/test_example_match.rb +3144 -3144
- data/test/test_formula.rb +61 -61
- data/test/test_ole.rb +106 -106
- data/test/test_storage_lite.rb +125 -125
- data/test/test_workbook.rb +139 -139
- data/test/test_worksheet.rb +110 -110
- data/utils/add_magic_comment.rb +80 -80
- data/writeexcel.gemspec +4 -6
- data/writeexcel.rdoc +58 -15
- metadata +9 -6
- data/test/test_new_encoding.rb +0 -205
data/examples/autofilter.rb
CHANGED
@@ -1,265 +1,265 @@
|
|
1
|
-
#!/usr/bin/ruby -w
|
2
|
-
# -*- coding: utf-8 -*-
|
3
|
-
|
4
|
-
#######################################################################
|
5
|
-
#
|
6
|
-
# Example of how to create autofilters with WriteExcel.
|
7
|
-
#
|
8
|
-
# reverse('©'), September 2007, John McNamara, jmcnamara@cpan.org
|
9
|
-
#
|
10
|
-
# original written in Perl by John McNamara
|
11
|
-
# converted to Ruby by Hideo Nakamura, cxn03651@msj.biglobe.ne.jp
|
12
|
-
#
|
13
|
-
require 'writeexcel'
|
14
|
-
|
15
|
-
def get_data
|
16
|
-
[
|
17
|
-
['East', 'Apple', 9000, 'July'],
|
18
|
-
['East', 'Apple', 5000, 'July'],
|
19
|
-
['South', 'Orange', 9000, 'September'],
|
20
|
-
['North', 'Apple', 2000, 'November'],
|
21
|
-
['West', 'Apple', 9000, 'November'],
|
22
|
-
['South', 'Pear', 7000, 'October'],
|
23
|
-
['North', 'Pear', 9000, 'August'],
|
24
|
-
['West', 'Orange', 1000, 'December'],
|
25
|
-
['West', 'Grape', 1000, 'November'],
|
26
|
-
['South', 'Pear', 10000, 'April'],
|
27
|
-
['West', 'Grape', 6000, 'January'],
|
28
|
-
['South', 'Orange', 3000, 'May'],
|
29
|
-
['North', 'Apple', 3000, 'December'],
|
30
|
-
['South', 'Apple', 7000, 'February'],
|
31
|
-
['West', 'Grape', 1000, 'December'],
|
32
|
-
['East', 'Grape', 8000, 'February'],
|
33
|
-
['South', 'Grape', 10000, 'June'],
|
34
|
-
['West', 'Pear', 7000, 'December'],
|
35
|
-
['South', 'Apple', 2000, 'October'],
|
36
|
-
['East', 'Grape', 7000, 'December'],
|
37
|
-
['North', 'Grape', 6000, 'April'],
|
38
|
-
['East', 'Pear', 8000, 'February'],
|
39
|
-
['North', 'Apple', 7000, 'August'],
|
40
|
-
['North', 'Orange', 7000, 'July'],
|
41
|
-
['North', 'Apple', 6000, 'June'],
|
42
|
-
['South', 'Grape', 8000, 'September'],
|
43
|
-
['West', 'Apple', 3000, 'October'],
|
44
|
-
['South', 'Orange', 10000, 'November'],
|
45
|
-
['West', 'Grape', 4000, 'July'],
|
46
|
-
['North', 'Orange', 5000, 'August'],
|
47
|
-
['East', 'Orange', 1000, 'November'],
|
48
|
-
['East', 'Orange', 4000, 'October'],
|
49
|
-
['North', 'Grape', 5000, 'August'],
|
50
|
-
['East', 'Apple', 1000, 'December'],
|
51
|
-
['South', 'Apple', 10000, 'March'],
|
52
|
-
['East', 'Grape', 7000, 'October'],
|
53
|
-
['West', 'Grape', 1000, 'September'],
|
54
|
-
['East', 'Grape', 10000, 'October'],
|
55
|
-
['South', 'Orange', 8000, 'March'],
|
56
|
-
['North', 'Apple', 4000, 'July'],
|
57
|
-
['South', 'Orange', 5000, 'July'],
|
58
|
-
['West', 'Apple', 4000, 'June'],
|
59
|
-
['East', 'Apple', 5000, 'April'],
|
60
|
-
['North', 'Pear', 3000, 'August'],
|
61
|
-
['East', 'Grape', 9000, 'November'],
|
62
|
-
['North', 'Orange', 8000, 'October'],
|
63
|
-
['East', 'Apple', 10000, 'June'],
|
64
|
-
['South', 'Pear', 1000, 'December'],
|
65
|
-
['North', 'Grape', 10000, 'July'],
|
66
|
-
['East', 'Grape', 6000, 'February'],
|
67
|
-
]
|
68
|
-
end
|
69
|
-
|
70
|
-
#######################################################################
|
71
|
-
#
|
72
|
-
# Main
|
73
|
-
#
|
74
|
-
|
75
|
-
xlsfile = 'autofilter.xls'
|
76
|
-
|
77
|
-
workbook = WriteExcel.new(xlsfile)
|
78
|
-
|
79
|
-
worksheet1 = workbook.add_worksheet
|
80
|
-
worksheet2 = workbook.add_worksheet
|
81
|
-
worksheet3 = workbook.add_worksheet
|
82
|
-
worksheet4 = workbook.add_worksheet
|
83
|
-
worksheet5 = workbook.add_worksheet
|
84
|
-
worksheet6 = workbook.add_worksheet
|
85
|
-
|
86
|
-
bold = workbook.add_format(:bold => 1)
|
87
|
-
|
88
|
-
# Extract the data embedded at the end of this file.
|
89
|
-
headings = %w(Region Item Volume Month)
|
90
|
-
data = get_data
|
91
|
-
|
92
|
-
# Set up several sheets with the same data.
|
93
|
-
workbook.sheets.each do |worksheet|
|
94
|
-
worksheet.set_column('A:D', 12)
|
95
|
-
worksheet.set_row(0, 20, bold)
|
96
|
-
worksheet.write('A1', headings)
|
97
|
-
end
|
98
|
-
|
99
|
-
###############################################################################
|
100
|
-
#
|
101
|
-
# Example 1. Autofilter without conditions.
|
102
|
-
#
|
103
|
-
|
104
|
-
worksheet1.autofilter('A1:D51')
|
105
|
-
worksheet1.write('A2', [data])
|
106
|
-
|
107
|
-
###############################################################################
|
108
|
-
#
|
109
|
-
#
|
110
|
-
# Example 2. Autofilter with a filter condition in the first column.
|
111
|
-
#
|
112
|
-
|
113
|
-
# The range in this example is the same as above but in row-column notation.
|
114
|
-
worksheet2.autofilter(0, 0, 50, 3)
|
115
|
-
|
116
|
-
# The placeholder "Region" in the filter is ignored and can be any string
|
117
|
-
# that adds clarity to the expression.
|
118
|
-
#
|
119
|
-
worksheet2.filter_column(0, 'Region eq East')
|
120
|
-
|
121
|
-
#
|
122
|
-
# Hide the rows that don't match the filter criteria.
|
123
|
-
#
|
124
|
-
row = 1
|
125
|
-
|
126
|
-
data.each do |row_data|
|
127
|
-
region = row_data[0]
|
128
|
-
|
129
|
-
if region == 'East'
|
130
|
-
# Row is visible.
|
131
|
-
else
|
132
|
-
# Hide row.
|
133
|
-
worksheet2.set_row(row, nil, nil, 1)
|
134
|
-
end
|
135
|
-
|
136
|
-
worksheet2.write(row, 0, row_data)
|
137
|
-
row += 1
|
138
|
-
end
|
139
|
-
|
140
|
-
|
141
|
-
###############################################################################
|
142
|
-
#
|
143
|
-
#
|
144
|
-
# Example 3. Autofilter with a dual filter condition in one of the columns.
|
145
|
-
#
|
146
|
-
|
147
|
-
worksheet3.autofilter('A1:D51')
|
148
|
-
|
149
|
-
worksheet3.filter_column('A', 'x eq East or x eq South')
|
150
|
-
|
151
|
-
#
|
152
|
-
# Hide the rows that don't match the filter criteria.
|
153
|
-
#
|
154
|
-
row = 1
|
155
|
-
|
156
|
-
data.each do |row_data|
|
157
|
-
region = row_data[0]
|
158
|
-
|
159
|
-
if region == 'East' || region == 'South'
|
160
|
-
# Row is visible.
|
161
|
-
else
|
162
|
-
# Hide row.
|
163
|
-
worksheet3.set_row(row, nil, nil, 1)
|
164
|
-
end
|
165
|
-
|
166
|
-
worksheet3.write(row, 0, row_data)
|
167
|
-
row += 1
|
168
|
-
end
|
169
|
-
|
170
|
-
|
171
|
-
###############################################################################
|
172
|
-
#
|
173
|
-
#
|
174
|
-
# Example 4. Autofilter with filter conditions in two columns.
|
175
|
-
#
|
176
|
-
|
177
|
-
worksheet4.autofilter('A1:D51')
|
178
|
-
|
179
|
-
worksheet4.filter_column('A', 'x eq East')
|
180
|
-
worksheet4.filter_column('C', 'x > 3000 and x < 8000' )
|
181
|
-
|
182
|
-
#
|
183
|
-
# Hide the rows that don't match the filter criteria.
|
184
|
-
#
|
185
|
-
row = 1
|
186
|
-
|
187
|
-
data.each do |row_data|
|
188
|
-
region = row_data[0]
|
189
|
-
volume = row_data[2]
|
190
|
-
|
191
|
-
if region == 'East' && volume > 3000 && volume < 8000
|
192
|
-
# Row is visible.
|
193
|
-
else
|
194
|
-
# Hide row.
|
195
|
-
worksheet4.set_row(row, nil, nil, 1)
|
196
|
-
end
|
197
|
-
|
198
|
-
worksheet4.write(row, 0, row_data)
|
199
|
-
row += 1
|
200
|
-
end
|
201
|
-
|
202
|
-
|
203
|
-
###############################################################################
|
204
|
-
#
|
205
|
-
#
|
206
|
-
# Example 5. Autofilter with filter for blanks.
|
207
|
-
#
|
208
|
-
|
209
|
-
# Create a blank cell in our test data.
|
210
|
-
data[5][0] = ''
|
211
|
-
|
212
|
-
worksheet5.autofilter('A1:D51')
|
213
|
-
worksheet5.filter_column('A', 'x == Blanks')
|
214
|
-
|
215
|
-
#
|
216
|
-
# Hide the rows that don't match the filter criteria.
|
217
|
-
#
|
218
|
-
row = 1
|
219
|
-
|
220
|
-
data.each do |row_data|
|
221
|
-
region = row_data[0]
|
222
|
-
|
223
|
-
if region == ''
|
224
|
-
# Row is visible.
|
225
|
-
else
|
226
|
-
# Hide row.
|
227
|
-
worksheet5.set_row(row, nil, nil, 1)
|
228
|
-
end
|
229
|
-
|
230
|
-
worksheet5.write(row, 0, row_data)
|
231
|
-
row += 1
|
232
|
-
end
|
233
|
-
|
234
|
-
|
235
|
-
###############################################################################
|
236
|
-
#
|
237
|
-
#
|
238
|
-
# Example 6. Autofilter with filter for non-blanks.
|
239
|
-
#
|
240
|
-
|
241
|
-
worksheet6.autofilter('A1:D51')
|
242
|
-
worksheet6.filter_column('A', 'x == NonBlanks')
|
243
|
-
|
244
|
-
#
|
245
|
-
# Hide the rows that don't match the filter criteria.
|
246
|
-
#
|
247
|
-
row = 1
|
248
|
-
|
249
|
-
data.each do |row_data|
|
250
|
-
region = row_data[0]
|
251
|
-
|
252
|
-
if region != ''
|
253
|
-
# Row is visible.
|
254
|
-
else
|
255
|
-
# Hide row.
|
256
|
-
worksheet6.set_row(row, nil, nil, 1)
|
257
|
-
end
|
258
|
-
|
259
|
-
worksheet6.write(row, 0, row_data)
|
260
|
-
row += 1
|
261
|
-
end
|
262
|
-
|
263
|
-
workbook.close
|
264
|
-
|
265
|
-
|
1
|
+
#!/usr/bin/ruby -w
|
2
|
+
# -*- coding: utf-8 -*-
|
3
|
+
|
4
|
+
#######################################################################
|
5
|
+
#
|
6
|
+
# Example of how to create autofilters with WriteExcel.
|
7
|
+
#
|
8
|
+
# reverse('©'), September 2007, John McNamara, jmcnamara@cpan.org
|
9
|
+
#
|
10
|
+
# original written in Perl by John McNamara
|
11
|
+
# converted to Ruby by Hideo Nakamura, cxn03651@msj.biglobe.ne.jp
|
12
|
+
#
|
13
|
+
require 'writeexcel'
|
14
|
+
|
15
|
+
def get_data
|
16
|
+
[
|
17
|
+
['East', 'Apple', 9000, 'July'],
|
18
|
+
['East', 'Apple', 5000, 'July'],
|
19
|
+
['South', 'Orange', 9000, 'September'],
|
20
|
+
['North', 'Apple', 2000, 'November'],
|
21
|
+
['West', 'Apple', 9000, 'November'],
|
22
|
+
['South', 'Pear', 7000, 'October'],
|
23
|
+
['North', 'Pear', 9000, 'August'],
|
24
|
+
['West', 'Orange', 1000, 'December'],
|
25
|
+
['West', 'Grape', 1000, 'November'],
|
26
|
+
['South', 'Pear', 10000, 'April'],
|
27
|
+
['West', 'Grape', 6000, 'January'],
|
28
|
+
['South', 'Orange', 3000, 'May'],
|
29
|
+
['North', 'Apple', 3000, 'December'],
|
30
|
+
['South', 'Apple', 7000, 'February'],
|
31
|
+
['West', 'Grape', 1000, 'December'],
|
32
|
+
['East', 'Grape', 8000, 'February'],
|
33
|
+
['South', 'Grape', 10000, 'June'],
|
34
|
+
['West', 'Pear', 7000, 'December'],
|
35
|
+
['South', 'Apple', 2000, 'October'],
|
36
|
+
['East', 'Grape', 7000, 'December'],
|
37
|
+
['North', 'Grape', 6000, 'April'],
|
38
|
+
['East', 'Pear', 8000, 'February'],
|
39
|
+
['North', 'Apple', 7000, 'August'],
|
40
|
+
['North', 'Orange', 7000, 'July'],
|
41
|
+
['North', 'Apple', 6000, 'June'],
|
42
|
+
['South', 'Grape', 8000, 'September'],
|
43
|
+
['West', 'Apple', 3000, 'October'],
|
44
|
+
['South', 'Orange', 10000, 'November'],
|
45
|
+
['West', 'Grape', 4000, 'July'],
|
46
|
+
['North', 'Orange', 5000, 'August'],
|
47
|
+
['East', 'Orange', 1000, 'November'],
|
48
|
+
['East', 'Orange', 4000, 'October'],
|
49
|
+
['North', 'Grape', 5000, 'August'],
|
50
|
+
['East', 'Apple', 1000, 'December'],
|
51
|
+
['South', 'Apple', 10000, 'March'],
|
52
|
+
['East', 'Grape', 7000, 'October'],
|
53
|
+
['West', 'Grape', 1000, 'September'],
|
54
|
+
['East', 'Grape', 10000, 'October'],
|
55
|
+
['South', 'Orange', 8000, 'March'],
|
56
|
+
['North', 'Apple', 4000, 'July'],
|
57
|
+
['South', 'Orange', 5000, 'July'],
|
58
|
+
['West', 'Apple', 4000, 'June'],
|
59
|
+
['East', 'Apple', 5000, 'April'],
|
60
|
+
['North', 'Pear', 3000, 'August'],
|
61
|
+
['East', 'Grape', 9000, 'November'],
|
62
|
+
['North', 'Orange', 8000, 'October'],
|
63
|
+
['East', 'Apple', 10000, 'June'],
|
64
|
+
['South', 'Pear', 1000, 'December'],
|
65
|
+
['North', 'Grape', 10000, 'July'],
|
66
|
+
['East', 'Grape', 6000, 'February'],
|
67
|
+
]
|
68
|
+
end
|
69
|
+
|
70
|
+
#######################################################################
|
71
|
+
#
|
72
|
+
# Main
|
73
|
+
#
|
74
|
+
|
75
|
+
xlsfile = 'autofilter.xls'
|
76
|
+
|
77
|
+
workbook = WriteExcel.new(xlsfile)
|
78
|
+
|
79
|
+
worksheet1 = workbook.add_worksheet
|
80
|
+
worksheet2 = workbook.add_worksheet
|
81
|
+
worksheet3 = workbook.add_worksheet
|
82
|
+
worksheet4 = workbook.add_worksheet
|
83
|
+
worksheet5 = workbook.add_worksheet
|
84
|
+
worksheet6 = workbook.add_worksheet
|
85
|
+
|
86
|
+
bold = workbook.add_format(:bold => 1)
|
87
|
+
|
88
|
+
# Extract the data embedded at the end of this file.
|
89
|
+
headings = %w(Region Item Volume Month)
|
90
|
+
data = get_data
|
91
|
+
|
92
|
+
# Set up several sheets with the same data.
|
93
|
+
workbook.sheets.each do |worksheet|
|
94
|
+
worksheet.set_column('A:D', 12)
|
95
|
+
worksheet.set_row(0, 20, bold)
|
96
|
+
worksheet.write('A1', headings)
|
97
|
+
end
|
98
|
+
|
99
|
+
###############################################################################
|
100
|
+
#
|
101
|
+
# Example 1. Autofilter without conditions.
|
102
|
+
#
|
103
|
+
|
104
|
+
worksheet1.autofilter('A1:D51')
|
105
|
+
worksheet1.write('A2', [data])
|
106
|
+
|
107
|
+
###############################################################################
|
108
|
+
#
|
109
|
+
#
|
110
|
+
# Example 2. Autofilter with a filter condition in the first column.
|
111
|
+
#
|
112
|
+
|
113
|
+
# The range in this example is the same as above but in row-column notation.
|
114
|
+
worksheet2.autofilter(0, 0, 50, 3)
|
115
|
+
|
116
|
+
# The placeholder "Region" in the filter is ignored and can be any string
|
117
|
+
# that adds clarity to the expression.
|
118
|
+
#
|
119
|
+
worksheet2.filter_column(0, 'Region eq East')
|
120
|
+
|
121
|
+
#
|
122
|
+
# Hide the rows that don't match the filter criteria.
|
123
|
+
#
|
124
|
+
row = 1
|
125
|
+
|
126
|
+
data.each do |row_data|
|
127
|
+
region = row_data[0]
|
128
|
+
|
129
|
+
if region == 'East'
|
130
|
+
# Row is visible.
|
131
|
+
else
|
132
|
+
# Hide row.
|
133
|
+
worksheet2.set_row(row, nil, nil, 1)
|
134
|
+
end
|
135
|
+
|
136
|
+
worksheet2.write(row, 0, row_data)
|
137
|
+
row += 1
|
138
|
+
end
|
139
|
+
|
140
|
+
|
141
|
+
###############################################################################
|
142
|
+
#
|
143
|
+
#
|
144
|
+
# Example 3. Autofilter with a dual filter condition in one of the columns.
|
145
|
+
#
|
146
|
+
|
147
|
+
worksheet3.autofilter('A1:D51')
|
148
|
+
|
149
|
+
worksheet3.filter_column('A', 'x eq East or x eq South')
|
150
|
+
|
151
|
+
#
|
152
|
+
# Hide the rows that don't match the filter criteria.
|
153
|
+
#
|
154
|
+
row = 1
|
155
|
+
|
156
|
+
data.each do |row_data|
|
157
|
+
region = row_data[0]
|
158
|
+
|
159
|
+
if region == 'East' || region == 'South'
|
160
|
+
# Row is visible.
|
161
|
+
else
|
162
|
+
# Hide row.
|
163
|
+
worksheet3.set_row(row, nil, nil, 1)
|
164
|
+
end
|
165
|
+
|
166
|
+
worksheet3.write(row, 0, row_data)
|
167
|
+
row += 1
|
168
|
+
end
|
169
|
+
|
170
|
+
|
171
|
+
###############################################################################
|
172
|
+
#
|
173
|
+
#
|
174
|
+
# Example 4. Autofilter with filter conditions in two columns.
|
175
|
+
#
|
176
|
+
|
177
|
+
worksheet4.autofilter('A1:D51')
|
178
|
+
|
179
|
+
worksheet4.filter_column('A', 'x eq East')
|
180
|
+
worksheet4.filter_column('C', 'x > 3000 and x < 8000' )
|
181
|
+
|
182
|
+
#
|
183
|
+
# Hide the rows that don't match the filter criteria.
|
184
|
+
#
|
185
|
+
row = 1
|
186
|
+
|
187
|
+
data.each do |row_data|
|
188
|
+
region = row_data[0]
|
189
|
+
volume = row_data[2]
|
190
|
+
|
191
|
+
if region == 'East' && volume > 3000 && volume < 8000
|
192
|
+
# Row is visible.
|
193
|
+
else
|
194
|
+
# Hide row.
|
195
|
+
worksheet4.set_row(row, nil, nil, 1)
|
196
|
+
end
|
197
|
+
|
198
|
+
worksheet4.write(row, 0, row_data)
|
199
|
+
row += 1
|
200
|
+
end
|
201
|
+
|
202
|
+
|
203
|
+
###############################################################################
|
204
|
+
#
|
205
|
+
#
|
206
|
+
# Example 5. Autofilter with filter for blanks.
|
207
|
+
#
|
208
|
+
|
209
|
+
# Create a blank cell in our test data.
|
210
|
+
data[5][0] = ''
|
211
|
+
|
212
|
+
worksheet5.autofilter('A1:D51')
|
213
|
+
worksheet5.filter_column('A', 'x == Blanks')
|
214
|
+
|
215
|
+
#
|
216
|
+
# Hide the rows that don't match the filter criteria.
|
217
|
+
#
|
218
|
+
row = 1
|
219
|
+
|
220
|
+
data.each do |row_data|
|
221
|
+
region = row_data[0]
|
222
|
+
|
223
|
+
if region == ''
|
224
|
+
# Row is visible.
|
225
|
+
else
|
226
|
+
# Hide row.
|
227
|
+
worksheet5.set_row(row, nil, nil, 1)
|
228
|
+
end
|
229
|
+
|
230
|
+
worksheet5.write(row, 0, row_data)
|
231
|
+
row += 1
|
232
|
+
end
|
233
|
+
|
234
|
+
|
235
|
+
###############################################################################
|
236
|
+
#
|
237
|
+
#
|
238
|
+
# Example 6. Autofilter with filter for non-blanks.
|
239
|
+
#
|
240
|
+
|
241
|
+
worksheet6.autofilter('A1:D51')
|
242
|
+
worksheet6.filter_column('A', 'x == NonBlanks')
|
243
|
+
|
244
|
+
#
|
245
|
+
# Hide the rows that don't match the filter criteria.
|
246
|
+
#
|
247
|
+
row = 1
|
248
|
+
|
249
|
+
data.each do |row_data|
|
250
|
+
region = row_data[0]
|
251
|
+
|
252
|
+
if region != ''
|
253
|
+
# Row is visible.
|
254
|
+
else
|
255
|
+
# Hide row.
|
256
|
+
worksheet6.set_row(row, nil, nil, 1)
|
257
|
+
end
|
258
|
+
|
259
|
+
worksheet6.write(row, 0, row_data)
|
260
|
+
row += 1
|
261
|
+
end
|
262
|
+
|
263
|
+
workbook.close
|
264
|
+
|
265
|
+
|
data/examples/bigfile.rb
CHANGED
@@ -1,30 +1,30 @@
|
|
1
|
-
#!/usr/bin/ruby -w
|
2
|
-
# -*- coding: utf-8 -*-
|
3
|
-
|
4
|
-
###############################################################################
|
5
|
-
#
|
6
|
-
# Example of creating a WriteExcel that is larger than the
|
7
|
-
# default 7MB limit.
|
8
|
-
#
|
9
|
-
# It is exactly that same as any other WriteExcel program except
|
10
|
-
# that is requires that the OLE::Storage module is installed.
|
11
|
-
#
|
12
|
-
# reverse('©'), Jan 2007, John McNamara, jmcnamara@cpan.org
|
13
|
-
#
|
14
|
-
# original written in Perl by John McNamara
|
15
|
-
# converted to Ruby by Hideo Nakamura, cxn03651@msj.biglobe.ne.jp
|
16
|
-
#
|
17
|
-
require 'writeexcel'
|
18
|
-
|
19
|
-
workbook = WriteExcel.new('bigfile.xls')
|
20
|
-
worksheet = workbook.add_worksheet
|
21
|
-
|
22
|
-
worksheet.set_column(0, 50, 18)
|
23
|
-
|
24
|
-
0.upto(50) do |col|
|
25
|
-
0.upto(6000) do |row|
|
26
|
-
worksheet.write(row, col, "Row: #{row} Col: #{col}")
|
27
|
-
end
|
28
|
-
end
|
29
|
-
|
30
|
-
workbook.close
|
1
|
+
#!/usr/bin/ruby -w
|
2
|
+
# -*- coding: utf-8 -*-
|
3
|
+
|
4
|
+
###############################################################################
|
5
|
+
#
|
6
|
+
# Example of creating a WriteExcel that is larger than the
|
7
|
+
# default 7MB limit.
|
8
|
+
#
|
9
|
+
# It is exactly that same as any other WriteExcel program except
|
10
|
+
# that is requires that the OLE::Storage module is installed.
|
11
|
+
#
|
12
|
+
# reverse('©'), Jan 2007, John McNamara, jmcnamara@cpan.org
|
13
|
+
#
|
14
|
+
# original written in Perl by John McNamara
|
15
|
+
# converted to Ruby by Hideo Nakamura, cxn03651@msj.biglobe.ne.jp
|
16
|
+
#
|
17
|
+
require 'writeexcel'
|
18
|
+
|
19
|
+
workbook = WriteExcel.new('bigfile.xls')
|
20
|
+
worksheet = workbook.add_worksheet
|
21
|
+
|
22
|
+
worksheet.set_column(0, 50, 18)
|
23
|
+
|
24
|
+
0.upto(50) do |col|
|
25
|
+
0.upto(6000) do |row|
|
26
|
+
worksheet.write(row, col, "Row: #{row} Col: #{col}")
|
27
|
+
end
|
28
|
+
end
|
29
|
+
|
30
|
+
workbook.close
|