#!/usr/bin/env ruby # -*- coding: utf-8 -*- ####################################################################### # # A demo of an various Excel chart data tools that are available via # an WriteXLSX chart. # # These include, Trendlines, Data Labels, Error Bars, Drop Lines, # High-Low Lines and Up-Down Bars. # # reverse ('(c)'), December 2012, John McNamara, jmcnamara@cpan.org # convert to ruby by Hideo NAKAMURA, nakamura.hideo@gmail.com # require 'write_xlsx' # Create a new workbook called simple.xls and add a worksheet workbook = WriteXLSX.new('chart_data_tools.xlsx') worksheet = workbook.add_worksheet bold = workbook.add_format(:bold => 1) # Add the worksheet data that the charts will refer to. headings = [ 'Number', 'Data 1', 'Data 2' ] data = [ [ 2, 3, 4, 5, 6, 7 ], [ 10, 40, 50, 20, 10, 50 ], [ 30, 60, 70, 50, 40, 30 ] ] worksheet.write('A1', headings, bold) worksheet.write('A2', data) ####################################################################### # # Trendline example. # # Create a Line chart. chart1 = workbook.add_chart(:type => 'line', :embedded => 1) # Configure the first series with a polynomial trendline. chart1.add_series( :categories => '=Sheet1!$A$2:$A$7', :values => '=Sheet1!$B$2:$B$7', :trendline => { :type => 'polynomial', :order => 3, }, ) # Configure the second series with a moving average trendline. chart1.add_series( :categories => '=Sheet1!$A$2:$A$7', :values => '=Sheet1!$C$2:$C$7', :trendline => { :type => 'linear' }, ) # Add a chart title. and some axis labels. chart1.set_title(:name => 'Chart with Trendlines') # Insert the chart into the worksheet (with an offset). worksheet.insert_chart( 'D2', chart1, :x_offset => 25, :y_offset => 10 ) ####################################################################### # # Data Labels and Markers example. # # Create a Line chart. chart2 = workbook.add_chart(:type => 'line', :embedded => 1) # Configure the first series. chart2.add_series( :categories => '=Sheet1!$A$2:$A$7', :values => '=Sheet1!$B$2:$B$7', :data_labels => { :value => 1 }, :marker => { :type => 'automatic' }, ) # Configure the second series. chart2.add_series( :categories => '=Sheet1!$A$2:$A$7', :values => '=Sheet1!$C$2:$C$7', ) # Add a chart title. and some axis labels. chart2.set_title(:name => 'Chart with Data Labels and Markers') # Insert the chart into the worksheet (with an offset). worksheet.insert_chart( 'D18', chart2, :x_offset => 25, :y_offset => 10 ) ####################################################################### # # Error Bars example. # # Create a Line chart. chart3 = workbook.add_chart(:type => 'line', :embedded => 1) # Configure the first series. chart3.add_series( :categories => '=Sheet1!$A$2:$A$7', :values => '=Sheet1!$B$2:$B$7', :y_error_bars => { :type => 'standard_error' }, ) # Configure the second series. chart3.add_series( :categories => '=Sheet1!$A$2:$A$7', :values => '=Sheet1!$C$2:$C$7', ) # Add a chart title. and some axis labels. chart3.set_title(:name => 'Chart with Error Bars') # Insert the chart into the worksheet (with an offset). worksheet.insert_chart( 'D34', chart3, :x_offset => 25, :y_offset => 10 ) ####################################################################### # # Up-Down Bars example. # # Create a Line chart. chart4 = workbook.add_chart(:type => 'line', :embedded => 1) # Add the Up-Down Bars. chart4.set_up_down_bars # Configure the first series. chart4.add_series( :categories => '=Sheet1!$A$2:$A$7', :values => '=Sheet1!$B$2:$B$7', ) # Configure the second series. chart4.add_series( :categories => '=Sheet1!$A$2:$A$7', :values => '=Sheet1!$C$2:$C$7', ) # Add a chart title. and some axis labels. chart4.set_title(:name => 'Chart with Up-Down Bars') # Insert the chart into the worksheet (with an offset). worksheet.insert_chart( 'D50', chart4, :x_offset => 25, :y_offset => 10 ) ####################################################################### # # High-Low Lines example. # # Create a Line chart. chart5 = workbook.add_chart(:type => 'line', :embedded => 1) # Add the High-Low lines. chart5.set_high_low_lines # Configure the first series. chart5.add_series( :categories => '=Sheet1!$A$2:$A$7', :values => '=Sheet1!$B$2:$B$7', ) # Configure the second series. chart5.add_series( :categories => '=Sheet1!$A$2:$A$7', :values => '=Sheet1!$C$2:$C$7', ) # Add a chart title. and some axis labels. chart5.set_title(:name => 'Chart with High-Low Lines') # Insert the chart into the worksheet (with an offset). worksheet.insert_chart( 'D66', chart5, :x_offset => 25, :y_offset => 10 ) ####################################################################### # # Drop Lines example. # # Create a Line chart. chart6 = workbook.add_chart(:type => 'line', :embedded => 1) # Add Drop Lines. chart6.set_drop_lines # Configure the first series. chart6.add_series( :categories => '=Sheet1!$A$2:$A$7', :values => '=Sheet1!$B$2:$B$7', ) # Configure the second series. chart6.add_series( :categories => '=Sheet1!$A$2:$A$7', :values => '=Sheet1!$C$2:$C$7', ) # Add a chart title. and some axis labels. chart6.set_title(:name => 'Chart with Drop Lines') # Insert the chart into the worksheet (with an offset). worksheet.insert_chart( 'D82', chart6, :x_offset => 25, :y_offset => 10 ) workbook.close