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/colors.rb
CHANGED
@@ -1,129 +1,129 @@
|
|
1
|
-
#!/usr/bin/ruby -w
|
2
|
-
# -*- coding: utf-8 -*-
|
3
|
-
|
4
|
-
################################################################################
|
5
|
-
#
|
6
|
-
# Demonstrates Spreadsheet::WriteExcel's named colors and the Excel color
|
7
|
-
# palette.
|
8
|
-
#
|
9
|
-
# The set_custom_color() Worksheet method can be used to override one of the
|
10
|
-
# built-in palette values with a more suitable colour. See the main docs.
|
11
|
-
#
|
12
|
-
# reverse('©'), March 2002, 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
|
-
|
18
|
-
require 'writeexcel'
|
19
|
-
|
20
|
-
workbook = WriteExcel.new("colors.xls")
|
21
|
-
|
22
|
-
# Some common formats
|
23
|
-
center = workbook.add_format(:align => 'center')
|
24
|
-
heading = workbook.add_format(:align => 'center', :bold => 1)
|
25
|
-
|
26
|
-
######################################################################
|
27
|
-
#
|
28
|
-
# Demonstrate the named colors.
|
29
|
-
#
|
30
|
-
|
31
|
-
order = [
|
32
|
-
0x21,
|
33
|
-
0x0B,
|
34
|
-
0x35,
|
35
|
-
0x11,
|
36
|
-
0x16,
|
37
|
-
0x12,
|
38
|
-
0x0D,
|
39
|
-
0x10,
|
40
|
-
0x17,
|
41
|
-
0x09,
|
42
|
-
0x0C,
|
43
|
-
0x0F,
|
44
|
-
0x0E,
|
45
|
-
0x14,
|
46
|
-
0x08,
|
47
|
-
0x0A
|
48
|
-
]
|
49
|
-
|
50
|
-
colors = {
|
51
|
-
0x08 => 'black',
|
52
|
-
0x0C => 'blue',
|
53
|
-
0x10 => 'brown',
|
54
|
-
0x0F => 'cyan',
|
55
|
-
0x17 => 'gray',
|
56
|
-
0x11 => 'green',
|
57
|
-
0x0B => 'lime',
|
58
|
-
0x0E => 'magenta',
|
59
|
-
0x12 => 'navy',
|
60
|
-
0x35 => 'orange',
|
61
|
-
0x21 => 'pink',
|
62
|
-
0x14 => 'purple',
|
63
|
-
0x0A => 'red',
|
64
|
-
0x16 => 'silver',
|
65
|
-
0x09 => 'white',
|
66
|
-
0x0D => 'yellow',
|
67
|
-
}
|
68
|
-
|
69
|
-
worksheet1 = workbook.add_worksheet('Named colors')
|
70
|
-
|
71
|
-
worksheet1.set_column(0, 3, 15)
|
72
|
-
|
73
|
-
worksheet1.write(0, 0, "Index", heading)
|
74
|
-
worksheet1.write(0, 1, "Index", heading)
|
75
|
-
worksheet1.write(0, 2, "Name", heading)
|
76
|
-
worksheet1.write(0, 3, "Color", heading)
|
77
|
-
|
78
|
-
i = 1
|
79
|
-
|
80
|
-
# original was colors.each....
|
81
|
-
# order unmatch between perl and ruby (of cource, it's hash!)
|
82
|
-
# so i use order array to match perl's xls order.
|
83
|
-
#
|
84
|
-
order.each do |index|
|
85
|
-
format = workbook.add_format(
|
86
|
-
:fg_color => colors[index],
|
87
|
-
:pattern => 1,
|
88
|
-
:border => 1
|
89
|
-
)
|
90
|
-
|
91
|
-
worksheet1.write(i + 1, 0, index, center)
|
92
|
-
worksheet1.write(i + 1, 1, sprintf("0x%02X", index), center)
|
93
|
-
worksheet1.write(i + 1, 2, colors[index], center)
|
94
|
-
worksheet1.write(i + 1, 3, '', format)
|
95
|
-
i += 1
|
96
|
-
end
|
97
|
-
|
98
|
-
######################################################################
|
99
|
-
#
|
100
|
-
# Demonstrate the standard Excel colors in the range 8..63.
|
101
|
-
#
|
102
|
-
|
103
|
-
worksheet2 = workbook.add_worksheet('Standard colors')
|
104
|
-
|
105
|
-
worksheet2.set_column(0, 3, 15)
|
106
|
-
|
107
|
-
worksheet2.write(0, 0, "Index", heading)
|
108
|
-
worksheet2.write(0, 1, "Index", heading)
|
109
|
-
worksheet2.write(0, 2, "Color", heading)
|
110
|
-
worksheet2.write(0, 3, "Name", heading)
|
111
|
-
|
112
|
-
(8..63).each do |i|
|
113
|
-
format = workbook.add_format(
|
114
|
-
:fg_color => i,
|
115
|
-
:pattern => 1,
|
116
|
-
:border => 1
|
117
|
-
)
|
118
|
-
|
119
|
-
worksheet2.write((i - 7), 0, i, center)
|
120
|
-
worksheet2.write((i - 7), 1, sprintf("0x%02X", i), center)
|
121
|
-
worksheet2.write((i - 7), 2, '', format)
|
122
|
-
|
123
|
-
# Add the color names
|
124
|
-
if colors.has_key?(i)
|
125
|
-
worksheet2.write((i - 7), 3, colors[i], center)
|
126
|
-
end
|
127
|
-
end
|
128
|
-
|
129
|
-
workbook.close
|
1
|
+
#!/usr/bin/ruby -w
|
2
|
+
# -*- coding: utf-8 -*-
|
3
|
+
|
4
|
+
################################################################################
|
5
|
+
#
|
6
|
+
# Demonstrates Spreadsheet::WriteExcel's named colors and the Excel color
|
7
|
+
# palette.
|
8
|
+
#
|
9
|
+
# The set_custom_color() Worksheet method can be used to override one of the
|
10
|
+
# built-in palette values with a more suitable colour. See the main docs.
|
11
|
+
#
|
12
|
+
# reverse('©'), March 2002, 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
|
+
|
18
|
+
require 'writeexcel'
|
19
|
+
|
20
|
+
workbook = WriteExcel.new("colors.xls")
|
21
|
+
|
22
|
+
# Some common formats
|
23
|
+
center = workbook.add_format(:align => 'center')
|
24
|
+
heading = workbook.add_format(:align => 'center', :bold => 1)
|
25
|
+
|
26
|
+
######################################################################
|
27
|
+
#
|
28
|
+
# Demonstrate the named colors.
|
29
|
+
#
|
30
|
+
|
31
|
+
order = [
|
32
|
+
0x21,
|
33
|
+
0x0B,
|
34
|
+
0x35,
|
35
|
+
0x11,
|
36
|
+
0x16,
|
37
|
+
0x12,
|
38
|
+
0x0D,
|
39
|
+
0x10,
|
40
|
+
0x17,
|
41
|
+
0x09,
|
42
|
+
0x0C,
|
43
|
+
0x0F,
|
44
|
+
0x0E,
|
45
|
+
0x14,
|
46
|
+
0x08,
|
47
|
+
0x0A
|
48
|
+
]
|
49
|
+
|
50
|
+
colors = {
|
51
|
+
0x08 => 'black',
|
52
|
+
0x0C => 'blue',
|
53
|
+
0x10 => 'brown',
|
54
|
+
0x0F => 'cyan',
|
55
|
+
0x17 => 'gray',
|
56
|
+
0x11 => 'green',
|
57
|
+
0x0B => 'lime',
|
58
|
+
0x0E => 'magenta',
|
59
|
+
0x12 => 'navy',
|
60
|
+
0x35 => 'orange',
|
61
|
+
0x21 => 'pink',
|
62
|
+
0x14 => 'purple',
|
63
|
+
0x0A => 'red',
|
64
|
+
0x16 => 'silver',
|
65
|
+
0x09 => 'white',
|
66
|
+
0x0D => 'yellow',
|
67
|
+
}
|
68
|
+
|
69
|
+
worksheet1 = workbook.add_worksheet('Named colors')
|
70
|
+
|
71
|
+
worksheet1.set_column(0, 3, 15)
|
72
|
+
|
73
|
+
worksheet1.write(0, 0, "Index", heading)
|
74
|
+
worksheet1.write(0, 1, "Index", heading)
|
75
|
+
worksheet1.write(0, 2, "Name", heading)
|
76
|
+
worksheet1.write(0, 3, "Color", heading)
|
77
|
+
|
78
|
+
i = 1
|
79
|
+
|
80
|
+
# original was colors.each....
|
81
|
+
# order unmatch between perl and ruby (of cource, it's hash!)
|
82
|
+
# so i use order array to match perl's xls order.
|
83
|
+
#
|
84
|
+
order.each do |index|
|
85
|
+
format = workbook.add_format(
|
86
|
+
:fg_color => colors[index],
|
87
|
+
:pattern => 1,
|
88
|
+
:border => 1
|
89
|
+
)
|
90
|
+
|
91
|
+
worksheet1.write(i + 1, 0, index, center)
|
92
|
+
worksheet1.write(i + 1, 1, sprintf("0x%02X", index), center)
|
93
|
+
worksheet1.write(i + 1, 2, colors[index], center)
|
94
|
+
worksheet1.write(i + 1, 3, '', format)
|
95
|
+
i += 1
|
96
|
+
end
|
97
|
+
|
98
|
+
######################################################################
|
99
|
+
#
|
100
|
+
# Demonstrate the standard Excel colors in the range 8..63.
|
101
|
+
#
|
102
|
+
|
103
|
+
worksheet2 = workbook.add_worksheet('Standard colors')
|
104
|
+
|
105
|
+
worksheet2.set_column(0, 3, 15)
|
106
|
+
|
107
|
+
worksheet2.write(0, 0, "Index", heading)
|
108
|
+
worksheet2.write(0, 1, "Index", heading)
|
109
|
+
worksheet2.write(0, 2, "Color", heading)
|
110
|
+
worksheet2.write(0, 3, "Name", heading)
|
111
|
+
|
112
|
+
(8..63).each do |i|
|
113
|
+
format = workbook.add_format(
|
114
|
+
:fg_color => i,
|
115
|
+
:pattern => 1,
|
116
|
+
:border => 1
|
117
|
+
)
|
118
|
+
|
119
|
+
worksheet2.write((i - 7), 0, i, center)
|
120
|
+
worksheet2.write((i - 7), 1, sprintf("0x%02X", i), center)
|
121
|
+
worksheet2.write((i - 7), 2, '', format)
|
122
|
+
|
123
|
+
# Add the color names
|
124
|
+
if colors.has_key?(i)
|
125
|
+
worksheet2.write((i - 7), 3, colors[i], center)
|
126
|
+
end
|
127
|
+
end
|
128
|
+
|
129
|
+
workbook.close
|
data/examples/comments1.rb
CHANGED
@@ -1,27 +1,27 @@
|
|
1
|
-
#!/usr/bin/ruby -w
|
2
|
-
# -*- coding: utf-8 -*-
|
3
|
-
|
4
|
-
###############################################################################
|
5
|
-
#
|
6
|
-
# This example demonstrates writing cell comments.
|
7
|
-
#
|
8
|
-
# A cell comment is indicated in Excel by a small red triangle in the upper
|
9
|
-
# right-hand corner of the cell.
|
10
|
-
#
|
11
|
-
# For more advanced comment options see comments2.pl.
|
12
|
-
#
|
13
|
-
# reverse('©'), November 2005, John McNamara, jmcnamara@cpan.org
|
14
|
-
#
|
15
|
-
# original written in Perl by John McNamara
|
16
|
-
# converted to Ruby by Hideo Nakamura, cxn03651@msj.biglobe.ne.jp
|
17
|
-
#
|
18
|
-
|
19
|
-
require 'writeexcel'
|
20
|
-
|
21
|
-
workbook = WriteExcel.new("comments1.xls")
|
22
|
-
worksheet = workbook.add_worksheet
|
23
|
-
|
24
|
-
worksheet.write('A1', 'Hello')
|
25
|
-
worksheet.write_comment('A1', 'This is a comment')
|
26
|
-
|
27
|
-
workbook.close
|
1
|
+
#!/usr/bin/ruby -w
|
2
|
+
# -*- coding: utf-8 -*-
|
3
|
+
|
4
|
+
###############################################################################
|
5
|
+
#
|
6
|
+
# This example demonstrates writing cell comments.
|
7
|
+
#
|
8
|
+
# A cell comment is indicated in Excel by a small red triangle in the upper
|
9
|
+
# right-hand corner of the cell.
|
10
|
+
#
|
11
|
+
# For more advanced comment options see comments2.pl.
|
12
|
+
#
|
13
|
+
# reverse('©'), November 2005, John McNamara, jmcnamara@cpan.org
|
14
|
+
#
|
15
|
+
# original written in Perl by John McNamara
|
16
|
+
# converted to Ruby by Hideo Nakamura, cxn03651@msj.biglobe.ne.jp
|
17
|
+
#
|
18
|
+
|
19
|
+
require 'writeexcel'
|
20
|
+
|
21
|
+
workbook = WriteExcel.new("comments1.xls")
|
22
|
+
worksheet = workbook.add_worksheet
|
23
|
+
|
24
|
+
worksheet.write('A1', 'Hello')
|
25
|
+
worksheet.write_comment('A1', 'This is a comment')
|
26
|
+
|
27
|
+
workbook.close
|