summaryrefslogtreecommitdiffhomepage
path: root/examples/column_outlines_example.md
blob: 6d402af54607de019a9e3d6155d6157c6508d418 (plain)
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
## Description

If you have a list of data that you want to group and summarize, you can create an outline of up to eight levels. Each inner level, represented by a higher number in the outline symbols, displays detail data for the preceding outer level, represented by a lower number in the outline symbols.

## Code

```ruby
require 'axlsx'

p = Axlsx::Package.new
wb = p.workbook

s = wb.styles
header = s.add_style bg_color: 'ADD8E6'
summary = s.add_style b: true

wb.add_worksheet(name: 'Column outlines') do |sheet|
  # Header
  sheet.add_row ['Name', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Summary'], style: header
  sheet.add_row ['Alice', 51, 67, 46, 23, 82, '=sum(B2:F2)']
  sheet.add_row ['Bob', 2, 97, 73, 9, 67, '=sum(B3:F3)']

  sheet.outline_level_columns 1, 5, 1, false # From col 1 to col 5, level 1, open
end

p.serialize 'column_outlines_example.xlsx'
```

## Output

![Output](images/column_outlines_example_1.png "Output")

After closing the outline:

![Output](images/column_outlines_example_2.png "Output")