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.
Files changed (130) hide show
  1. data/.gitattributes +1 -1
  2. data/.gitignore +24 -24
  3. data/README.rdoc +34 -55
  4. data/VERSION +1 -1
  5. data/charts/chartex.rb +316 -316
  6. data/charts/demo1.rb +46 -46
  7. data/charts/demo2.rb +65 -65
  8. data/charts/demo3.rb +117 -117
  9. data/charts/demo4.rb +119 -119
  10. data/charts/demo5.rb +48 -48
  11. data/examples/a_simple.rb +43 -43
  12. data/examples/autofilter.rb +265 -265
  13. data/examples/bigfile.rb +30 -30
  14. data/examples/chart_area.rb +121 -121
  15. data/examples/chart_bar.rb +120 -120
  16. data/examples/chart_column.rb +120 -120
  17. data/examples/chart_line.rb +120 -120
  18. data/examples/chart_pie.rb +108 -108
  19. data/examples/chart_scatter.rb +121 -121
  20. data/examples/chart_stock.rb +148 -148
  21. data/examples/chess.rb +142 -142
  22. data/examples/colors.rb +129 -129
  23. data/examples/comments1.rb +27 -27
  24. data/examples/comments2.rb +352 -352
  25. data/examples/copyformat.rb +52 -52
  26. data/examples/data_validate.rb +279 -279
  27. data/examples/date_time.rb +87 -87
  28. data/examples/defined_name.rb +32 -32
  29. data/examples/demo.rb +124 -124
  30. data/examples/diag_border.rb +36 -36
  31. data/examples/formats.rb +490 -490
  32. data/examples/formula_result.rb +30 -30
  33. data/examples/header.rb +137 -137
  34. data/examples/hide_sheet.rb +29 -29
  35. data/examples/hyperlink.rb +43 -43
  36. data/examples/images.rb +63 -63
  37. data/examples/indent.rb +31 -31
  38. data/examples/merge1.rb +40 -40
  39. data/examples/merge2.rb +45 -45
  40. data/examples/merge3.rb +66 -66
  41. data/examples/merge4.rb +83 -83
  42. data/examples/merge5.rb +80 -80
  43. data/examples/merge6.rb +67 -67
  44. data/examples/outline.rb +255 -255
  45. data/examples/outline_collapsed.rb +209 -209
  46. data/examples/panes.rb +113 -113
  47. data/examples/properties.rb +34 -34
  48. data/examples/properties_jp.rb +33 -33
  49. data/examples/protection.rb +47 -47
  50. data/examples/regions.rb +53 -53
  51. data/examples/repeat.rb +43 -43
  52. data/examples/right_to_left.rb +27 -27
  53. data/examples/row_wrap.rb +53 -53
  54. data/examples/stats.rb +74 -74
  55. data/examples/stocks.rb +81 -81
  56. data/examples/tab_colors.rb +31 -31
  57. data/examples/utf8.rb +15 -15
  58. data/examples/write_arrays.rb +83 -83
  59. data/lib/writeexcel/biffwriter.rb +232 -232
  60. data/lib/writeexcel/caller_info.rb +12 -12
  61. data/lib/writeexcel/chart.rb +2190 -2177
  62. data/lib/writeexcel/charts/area.rb +154 -154
  63. data/lib/writeexcel/charts/bar.rb +177 -177
  64. data/lib/writeexcel/charts/column.rb +156 -156
  65. data/lib/writeexcel/charts/external.rb +66 -66
  66. data/lib/writeexcel/charts/line.rb +154 -154
  67. data/lib/writeexcel/charts/pie.rb +169 -169
  68. data/lib/writeexcel/charts/scatter.rb +192 -192
  69. data/lib/writeexcel/charts/stock.rb +213 -213
  70. data/lib/writeexcel/colors.rb +64 -64
  71. data/lib/writeexcel/compatibility.rb +0 -255
  72. data/lib/writeexcel/debug_info.rb +37 -33
  73. data/lib/writeexcel/excelformulaparser.rb +587 -587
  74. data/lib/writeexcel/format.rb +13 -4
  75. data/lib/writeexcel/formula.rb +26 -9
  76. data/lib/writeexcel/helper.rb +68 -64
  77. data/lib/writeexcel/olewriter.rb +311 -311
  78. data/lib/writeexcel/properties.rb +242 -240
  79. data/lib/writeexcel/storage_lite.rb +984 -978
  80. data/lib/writeexcel/workbook.rb +3210 -3192
  81. data/lib/writeexcel/worksheet.rb +143 -51
  82. data/lib/writeexcel/write_file.rb +44 -40
  83. data/lib/writeexcel.rb +1159 -1159
  84. data/test/helper.rb +31 -28
  85. data/test/perl_output/README +31 -31
  86. data/test/test_00_IEEE_double.rb +13 -13
  87. data/test/test_01_add_worksheet.rb +10 -10
  88. data/test/test_02_merge_formats.rb +53 -53
  89. data/test/test_04_dimensions.rb +392 -392
  90. data/test/test_05_rows.rb +179 -179
  91. data/test/test_06_extsst.rb +77 -77
  92. data/test/test_11_date_time.rb +479 -479
  93. data/test/test_12_date_only.rb +501 -501
  94. data/test/test_13_date_seconds.rb +481 -481
  95. data/test/test_21_escher.rb +637 -637
  96. data/test/test_22_mso_drawing_group.rb +745 -745
  97. data/test/test_23_note.rb +73 -73
  98. data/test/test_24_txo.rb +75 -75
  99. data/test/test_25_position_object.rb +84 -84
  100. data/test/test_26_autofilter.rb +314 -314
  101. data/test/test_27_autofilter.rb +131 -131
  102. data/test/test_28_autofilter.rb +161 -161
  103. data/test/test_29_process_jpg.rb +683 -683
  104. data/test/test_30_validation_dval.rb +77 -77
  105. data/test/test_31_validation_dv_strings.rb +126 -126
  106. data/test/test_32_validation_dv_formula.rb +206 -206
  107. data/test/test_40_property_types.rb +188 -188
  108. data/test/test_41_properties.rb +235 -235
  109. data/test/test_42_set_properties.rb +437 -437
  110. data/test/test_50_name_stored.rb +299 -299
  111. data/test/test_51_name_print_area.rb +357 -357
  112. data/test/test_52_name_print_titles.rb +454 -454
  113. data/test/test_53_autofilter.rb +203 -203
  114. data/test/test_60_chart_generic.rb +578 -578
  115. data/test/test_61_chart_subclasses.rb +95 -95
  116. data/test/test_62_chart_formats.rb +272 -272
  117. data/test/test_63_chart_area_formats.rb +649 -649
  118. data/test/test_biff.rb +75 -75
  119. data/test/test_compatibility.rb +12 -627
  120. data/test/test_example_match.rb +3144 -3144
  121. data/test/test_formula.rb +61 -61
  122. data/test/test_ole.rb +106 -106
  123. data/test/test_storage_lite.rb +125 -125
  124. data/test/test_workbook.rb +139 -139
  125. data/test/test_worksheet.rb +110 -110
  126. data/utils/add_magic_comment.rb +80 -80
  127. data/writeexcel.gemspec +4 -6
  128. data/writeexcel.rdoc +58 -15
  129. metadata +9 -6
  130. data/test/test_new_encoding.rb +0 -205
data/examples/merge1.rb CHANGED
@@ -1,40 +1,40 @@
1
- #!/usr/bin/ruby -w
2
- # -*- coding: utf-8 -*-
3
-
4
- ###############################################################################
5
- #
6
- # Simple example of merging cells using the WriteExcel module.
7
- #
8
- # This merges three cells using the "Centre Across Selection" alignment.
9
- # This was the Excel 5 method of achieving a merge. Use the merge_range()
10
- # worksheet method instead. See merge3.pl - merge6.pl.
11
- #
12
- # reverse('©'), August 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 'rubygems'
19
- require 'writeexcel'
20
-
21
- # Create a new workbook and add a worksheet
22
- workbook = WriteExcel.new('merge1.xls')
23
- worksheet = workbook.add_worksheet
24
-
25
-
26
- # Increase the cell size of the merged cells to highlight the formatting.
27
- worksheet.set_column('B:D', 20)
28
- worksheet.set_row(2, 30)
29
-
30
-
31
- # Create a merge format
32
- format = workbook.add_format(:center_across => 1)
33
-
34
-
35
- # Only one cell should contain text, the others should be blank.
36
- worksheet.write(2, 1, "Center across selection", format)
37
- worksheet.write_blank(2, 2, format)
38
- worksheet.write_blank(2, 3, format)
39
-
40
- workbook.close
1
+ #!/usr/bin/ruby -w
2
+ # -*- coding: utf-8 -*-
3
+
4
+ ###############################################################################
5
+ #
6
+ # Simple example of merging cells using the WriteExcel module.
7
+ #
8
+ # This merges three cells using the "Centre Across Selection" alignment.
9
+ # This was the Excel 5 method of achieving a merge. Use the merge_range()
10
+ # worksheet method instead. See merge3.pl - merge6.pl.
11
+ #
12
+ # reverse('©'), August 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 'rubygems'
19
+ require 'writeexcel'
20
+
21
+ # Create a new workbook and add a worksheet
22
+ workbook = WriteExcel.new('merge1.xls')
23
+ worksheet = workbook.add_worksheet
24
+
25
+
26
+ # Increase the cell size of the merged cells to highlight the formatting.
27
+ worksheet.set_column('B:D', 20)
28
+ worksheet.set_row(2, 30)
29
+
30
+
31
+ # Create a merge format
32
+ format = workbook.add_format(:center_across => 1)
33
+
34
+
35
+ # Only one cell should contain text, the others should be blank.
36
+ worksheet.write(2, 1, "Center across selection", format)
37
+ worksheet.write_blank(2, 2, format)
38
+ worksheet.write_blank(2, 3, format)
39
+
40
+ workbook.close
data/examples/merge2.rb CHANGED
@@ -1,45 +1,45 @@
1
- #!/usr/bin/ruby -w
2
- # -*- coding: utf-8 -*-
3
-
4
- ###############################################################################
5
- #
6
- # Simple example of merging cells using the WriteExcel module
7
- #
8
- # This merges two formatted cells using the "Centre Across Selection" alignment.
9
- # This was the Excel 5 method of achieving a merge. Use the merge_range()
10
- # worksheet method instead. See merge3.pl - merge6.pl.
11
- #
12
- # reverse('©'), August 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 'rubygems'
19
- require 'writeexcel'
20
-
21
- # Create a new workbook and add a worksheet
22
- workbook = WriteExcel.new("merge2.xls")
23
- worksheet = workbook.add_worksheet
24
-
25
- # Increase the cell size of the merged cells to highlight the formatting.
26
- worksheet.set_column(1, 2, 30)
27
- worksheet.set_row(2, 40)
28
-
29
- # Create a merged format
30
- format = workbook.add_format(
31
- :center_across => 1,
32
- :bold => 1,
33
- :size => 15,
34
- :pattern => 1,
35
- :border => 6,
36
- :color => 'white',
37
- :fg_color => 'green',
38
- :border_color => 'yellow',
39
- :align => 'vcenter'
40
- )
41
-
42
- # Only one cell should contain text, the others should be blank.
43
- worksheet.write(2, 1, "Center across selection", format)
44
- worksheet.write_blank(2, 2, format)
45
- workbook.close
1
+ #!/usr/bin/ruby -w
2
+ # -*- coding: utf-8 -*-
3
+
4
+ ###############################################################################
5
+ #
6
+ # Simple example of merging cells using the WriteExcel module
7
+ #
8
+ # This merges two formatted cells using the "Centre Across Selection" alignment.
9
+ # This was the Excel 5 method of achieving a merge. Use the merge_range()
10
+ # worksheet method instead. See merge3.pl - merge6.pl.
11
+ #
12
+ # reverse('©'), August 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 'rubygems'
19
+ require 'writeexcel'
20
+
21
+ # Create a new workbook and add a worksheet
22
+ workbook = WriteExcel.new("merge2.xls")
23
+ worksheet = workbook.add_worksheet
24
+
25
+ # Increase the cell size of the merged cells to highlight the formatting.
26
+ worksheet.set_column(1, 2, 30)
27
+ worksheet.set_row(2, 40)
28
+
29
+ # Create a merged format
30
+ format = workbook.add_format(
31
+ :center_across => 1,
32
+ :bold => 1,
33
+ :size => 15,
34
+ :pattern => 1,
35
+ :border => 6,
36
+ :color => 'white',
37
+ :fg_color => 'green',
38
+ :border_color => 'yellow',
39
+ :align => 'vcenter'
40
+ )
41
+
42
+ # Only one cell should contain text, the others should be blank.
43
+ worksheet.write(2, 1, "Center across selection", format)
44
+ worksheet.write_blank(2, 2, format)
45
+ workbook.close
data/examples/merge3.rb CHANGED
@@ -1,66 +1,66 @@
1
- #!/usr/bin/ruby -w
2
- # -*- coding: utf-8 -*-
3
-
4
- ###############################################################################
5
- #
6
- # Example of how to use WriteExcel to write a hyperlink in a
7
- # merged cell. There are two options write_url_range() with a standard merge
8
- # format or merge_range().
9
- #
10
- # reverse('©'), September 2002, John McNamara, jmcnamara@cpan.org
11
- #
12
- # original written in Perl by John McNamara
13
- # converted to Ruby by Hideo Nakamura, cxn03651@msj.biglobe.ne.jp
14
- #
15
-
16
- require 'rubygems'
17
- require 'writeexcel'
18
-
19
- # Create a new workbook and add a worksheet
20
- workbook = WriteExcel.new("merge3.xls")
21
- worksheet = workbook.add_worksheet()
22
-
23
- # Increase the cell size of the merged cells to highlight the formatting.
24
- [1, 3,6,7].each { |row| worksheet.set_row(row, 30) }
25
- worksheet.set_column('B:D', 20)
26
-
27
- bp=1
28
- ###############################################################################
29
- #
30
- # Example 1: Merge cells containing a hyperlink using write_url_range()
31
- # and the standard Excel 5+ merge property.
32
- #
33
- format1 = workbook.add_format(
34
- :center_across => 1,
35
- :border => 1,
36
- :underline => 1,
37
- :color => 'blue'
38
- )
39
-
40
- # Write the cells to be merged
41
- worksheet.write_url_range('B2:D2', 'http://www.perl.com', format1)
42
- worksheet.write_blank('C2', format1)
43
- worksheet.write_blank('D2', format1)
44
-
45
-
46
-
47
- ###############################################################################
48
- #
49
- # Example 2: Merge cells containing a hyperlink using merge_range().
50
- #
51
- format2 = workbook.add_format(
52
- :border => 1,
53
- :underline => 1,
54
- :color => 'blue',
55
- :align => 'center',
56
- :valign => 'vcenter'
57
- )
58
-
59
- # Merge 3 cells
60
- worksheet.merge_range('B4:D4', 'http://www.perl.com', format2)
61
-
62
-
63
- # Merge 3 cells over two rows
64
- worksheet.merge_range('B7:D8', 'http://www.perl.com', format2)
65
-
66
- workbook.close
1
+ #!/usr/bin/ruby -w
2
+ # -*- coding: utf-8 -*-
3
+
4
+ ###############################################################################
5
+ #
6
+ # Example of how to use WriteExcel to write a hyperlink in a
7
+ # merged cell. There are two options write_url_range() with a standard merge
8
+ # format or merge_range().
9
+ #
10
+ # reverse('©'), September 2002, John McNamara, jmcnamara@cpan.org
11
+ #
12
+ # original written in Perl by John McNamara
13
+ # converted to Ruby by Hideo Nakamura, cxn03651@msj.biglobe.ne.jp
14
+ #
15
+
16
+ require 'rubygems'
17
+ require 'writeexcel'
18
+
19
+ # Create a new workbook and add a worksheet
20
+ workbook = WriteExcel.new("merge3.xls")
21
+ worksheet = workbook.add_worksheet()
22
+
23
+ # Increase the cell size of the merged cells to highlight the formatting.
24
+ [1, 3,6,7].each { |row| worksheet.set_row(row, 30) }
25
+ worksheet.set_column('B:D', 20)
26
+
27
+ bp=1
28
+ ###############################################################################
29
+ #
30
+ # Example 1: Merge cells containing a hyperlink using write_url_range()
31
+ # and the standard Excel 5+ merge property.
32
+ #
33
+ format1 = workbook.add_format(
34
+ :center_across => 1,
35
+ :border => 1,
36
+ :underline => 1,
37
+ :color => 'blue'
38
+ )
39
+
40
+ # Write the cells to be merged
41
+ worksheet.write_url_range('B2:D2', 'http://www.perl.com', format1)
42
+ worksheet.write_blank('C2', format1)
43
+ worksheet.write_blank('D2', format1)
44
+
45
+
46
+
47
+ ###############################################################################
48
+ #
49
+ # Example 2: Merge cells containing a hyperlink using merge_range().
50
+ #
51
+ format2 = workbook.add_format(
52
+ :border => 1,
53
+ :underline => 1,
54
+ :color => 'blue',
55
+ :align => 'center',
56
+ :valign => 'vcenter'
57
+ )
58
+
59
+ # Merge 3 cells
60
+ worksheet.merge_range('B4:D4', 'http://www.perl.com', format2)
61
+
62
+
63
+ # Merge 3 cells over two rows
64
+ worksheet.merge_range('B7:D8', 'http://www.perl.com', format2)
65
+
66
+ workbook.close
data/examples/merge4.rb CHANGED
@@ -1,83 +1,83 @@
1
- #!/usr/bin/ruby -w
2
- # -*- coding: utf-8 -*-
3
-
4
- ###############################################################################
5
- #
6
- # Example of how to use the WriteExcel merge_range() workbook
7
- # method with complex formatting.
8
- #
9
- # reverse('©'), September 2002, John McNamara, jmcnamara@cpan.org
10
- #
11
- # original written in Perl by John McNamara
12
- # converted to Ruby by Hideo Nakamura, cxn03651@msj.biglobe.ne.jp
13
- #
14
-
15
- require 'rubygems'
16
- require 'writeexcel'
17
-
18
- # Create a new workbook and add a worksheet
19
- workbook = WriteExcel.new('merge4.xls')
20
- worksheet = workbook.add_worksheet
21
-
22
- # Increase the cell size of the merged cells to highlight the formatting.
23
- (1..11).each { |row| worksheet.set_row(row, 30) }
24
- worksheet.set_column('B:D', 20)
25
-
26
- ###############################################################################
27
- #
28
- # Example 1: Text centered vertically and horizontally
29
- #
30
- format1 = workbook.add_format(
31
- :border => 6,
32
- :bold => 1,
33
- :color => 'red',
34
- :valign => 'vcenter',
35
- :align => 'center'
36
- )
37
-
38
- worksheet.merge_range('B2:D3', 'Vertical and horizontal', format1)
39
-
40
-
41
- ###############################################################################
42
- #
43
- # Example 2: Text aligned to the top and left
44
- #
45
- format2 = workbook.add_format(
46
- :border => 6,
47
- :bold => 1,
48
- :color => 'red',
49
- :valign => 'top',
50
- :align => 'left'
51
- )
52
-
53
- worksheet.merge_range('B5:D6', 'Aligned to the top and left', format2)
54
-
55
- ###############################################################################
56
- #
57
- # Example 3: Text aligned to the bottom and right
58
- #
59
- format3 = workbook.add_format(
60
- :border => 6,
61
- :bold => 1,
62
- :color => 'red',
63
- :valign => 'bottom',
64
- :align => 'right'
65
- )
66
-
67
- worksheet.merge_range('B8:D9', 'Aligned to the bottom and right', format3)
68
-
69
- ###############################################################################
70
- #
71
- # Example 4: Text justified (i.e. wrapped) in the cell
72
- #
73
- format4 = workbook.add_format(
74
- :border => 6,
75
- :bold => 1,
76
- :color => 'red',
77
- :valign => 'top',
78
- :align => 'justify'
79
- )
80
-
81
- worksheet.merge_range('B11:D12', 'Justified: '+'so on and '*18, format4)
82
-
83
- workbook.close
1
+ #!/usr/bin/ruby -w
2
+ # -*- coding: utf-8 -*-
3
+
4
+ ###############################################################################
5
+ #
6
+ # Example of how to use the WriteExcel merge_range() workbook
7
+ # method with complex formatting.
8
+ #
9
+ # reverse('©'), September 2002, John McNamara, jmcnamara@cpan.org
10
+ #
11
+ # original written in Perl by John McNamara
12
+ # converted to Ruby by Hideo Nakamura, cxn03651@msj.biglobe.ne.jp
13
+ #
14
+
15
+ require 'rubygems'
16
+ require 'writeexcel'
17
+
18
+ # Create a new workbook and add a worksheet
19
+ workbook = WriteExcel.new('merge4.xls')
20
+ worksheet = workbook.add_worksheet
21
+
22
+ # Increase the cell size of the merged cells to highlight the formatting.
23
+ (1..11).each { |row| worksheet.set_row(row, 30) }
24
+ worksheet.set_column('B:D', 20)
25
+
26
+ ###############################################################################
27
+ #
28
+ # Example 1: Text centered vertically and horizontally
29
+ #
30
+ format1 = workbook.add_format(
31
+ :border => 6,
32
+ :bold => 1,
33
+ :color => 'red',
34
+ :valign => 'vcenter',
35
+ :align => 'center'
36
+ )
37
+
38
+ worksheet.merge_range('B2:D3', 'Vertical and horizontal', format1)
39
+
40
+
41
+ ###############################################################################
42
+ #
43
+ # Example 2: Text aligned to the top and left
44
+ #
45
+ format2 = workbook.add_format(
46
+ :border => 6,
47
+ :bold => 1,
48
+ :color => 'red',
49
+ :valign => 'top',
50
+ :align => 'left'
51
+ )
52
+
53
+ worksheet.merge_range('B5:D6', 'Aligned to the top and left', format2)
54
+
55
+ ###############################################################################
56
+ #
57
+ # Example 3: Text aligned to the bottom and right
58
+ #
59
+ format3 = workbook.add_format(
60
+ :border => 6,
61
+ :bold => 1,
62
+ :color => 'red',
63
+ :valign => 'bottom',
64
+ :align => 'right'
65
+ )
66
+
67
+ worksheet.merge_range('B8:D9', 'Aligned to the bottom and right', format3)
68
+
69
+ ###############################################################################
70
+ #
71
+ # Example 4: Text justified (i.e. wrapped) in the cell
72
+ #
73
+ format4 = workbook.add_format(
74
+ :border => 6,
75
+ :bold => 1,
76
+ :color => 'red',
77
+ :valign => 'top',
78
+ :align => 'justify'
79
+ )
80
+
81
+ worksheet.merge_range('B11:D12', 'Justified: '+'so on and '*18, format4)
82
+
83
+ workbook.close
data/examples/merge5.rb CHANGED
@@ -1,80 +1,80 @@
1
- #!/usr/bin/ruby -w
2
- # -*- coding: utf-8 -*-
3
-
4
- ###############################################################################
5
- #
6
- # Example of how to use the WriteExcel merge_cells() workbook
7
- # method with complex formatting and rotation.
8
- #
9
- #
10
- # reverse('©'), September 2002, John McNamara, jmcnamara@cpan.org
11
- #
12
- # original written in Perl by John McNamara
13
- # converted to Ruby by Hideo Nakamura, cxn03651@msj.biglobe.ne.jp
14
- #
15
-
16
- require 'rubygems'
17
- require 'writeexcel'
18
-
19
- # Create a new workbook and add a worksheet
20
- workbook = WriteExcel.new('merge5.xls')
21
- worksheet = workbook.add_worksheet
22
-
23
-
24
- # Increase the cell size of the merged cells to highlight the formatting.
25
- (3..8).each { |col| worksheet.set_row(col, 36) }
26
- [1, 3, 5].each { |n| worksheet.set_column(n, n, 15) }
27
-
28
-
29
- ###############################################################################
30
- #
31
- # Rotation 1, letters run from top to bottom
32
- #
33
- format1 = workbook.add_format(
34
- :border => 6,
35
- :bold => 1,
36
- :color => 'red',
37
- :valign => 'vcentre',
38
- :align => 'centre',
39
- :rotation => 270
40
- )
41
-
42
-
43
- worksheet.merge_range('B4:B9', 'Rotation 270', format1)
44
-
45
-
46
- ###############################################################################
47
- #
48
- # Rotation 2, 90° anticlockwise
49
- #
50
- format2 = workbook.add_format(
51
- :border => 6,
52
- :bold => 1,
53
- :color => 'red',
54
- :valign => 'vcentre',
55
- :align => 'centre',
56
- :rotation => 90
57
- )
58
-
59
-
60
- worksheet.merge_range('D4:D9', 'Rotation 90°', format2)
61
-
62
-
63
-
64
- ###############################################################################
65
- #
66
- # Rotation 3, 90° clockwise
67
- #
68
- format3 = workbook.add_format(
69
- :border => 6,
70
- :bold => 1,
71
- :color => 'red',
72
- :valign => 'vcentre',
73
- :align => 'centre',
74
- :rotation => -90
75
- )
76
-
77
-
78
- worksheet.merge_range('F4:F9', 'Rotation -90°', format3)
79
-
80
- workbook.close
1
+ #!/usr/bin/ruby -w
2
+ # -*- coding: utf-8 -*-
3
+
4
+ ###############################################################################
5
+ #
6
+ # Example of how to use the WriteExcel merge_cells() workbook
7
+ # method with complex formatting and rotation.
8
+ #
9
+ #
10
+ # reverse('©'), September 2002, John McNamara, jmcnamara@cpan.org
11
+ #
12
+ # original written in Perl by John McNamara
13
+ # converted to Ruby by Hideo Nakamura, cxn03651@msj.biglobe.ne.jp
14
+ #
15
+
16
+ require 'rubygems'
17
+ require 'writeexcel'
18
+
19
+ # Create a new workbook and add a worksheet
20
+ workbook = WriteExcel.new('merge5.xls')
21
+ worksheet = workbook.add_worksheet
22
+
23
+
24
+ # Increase the cell size of the merged cells to highlight the formatting.
25
+ (3..8).each { |col| worksheet.set_row(col, 36) }
26
+ [1, 3, 5].each { |n| worksheet.set_column(n, n, 15) }
27
+
28
+
29
+ ###############################################################################
30
+ #
31
+ # Rotation 1, letters run from top to bottom
32
+ #
33
+ format1 = workbook.add_format(
34
+ :border => 6,
35
+ :bold => 1,
36
+ :color => 'red',
37
+ :valign => 'vcentre',
38
+ :align => 'centre',
39
+ :rotation => 270
40
+ )
41
+
42
+
43
+ worksheet.merge_range('B4:B9', 'Rotation 270', format1)
44
+
45
+
46
+ ###############################################################################
47
+ #
48
+ # Rotation 2, 90° anticlockwise
49
+ #
50
+ format2 = workbook.add_format(
51
+ :border => 6,
52
+ :bold => 1,
53
+ :color => 'red',
54
+ :valign => 'vcentre',
55
+ :align => 'centre',
56
+ :rotation => 90
57
+ )
58
+
59
+
60
+ worksheet.merge_range('D4:D9', 'Rotation 90°', format2)
61
+
62
+
63
+
64
+ ###############################################################################
65
+ #
66
+ # Rotation 3, 90° clockwise
67
+ #
68
+ format3 = workbook.add_format(
69
+ :border => 6,
70
+ :bold => 1,
71
+ :color => 'red',
72
+ :valign => 'vcentre',
73
+ :align => 'centre',
74
+ :rotation => -90
75
+ )
76
+
77
+
78
+ worksheet.merge_range('F4:F9', 'Rotation -90°', format3)
79
+
80
+ workbook.close