examples/example.rb in axlsx-1.0.10 vs examples/example.rb in axlsx-1.0.11

- old
+ new

@@ -7,53 +7,57 @@ #A Simple Workbook if ARGV.size == 0 || ARGV.include?("1") p = Axlsx::Package.new p.workbook.add_worksheet do |sheet| sheet.add_row ["First", "Second", "Third"] - sheet.add_row [1, 2, 3] + sheet.add_row [1, 2, Time.now] end p.serialize("example1.xlsx") end #Generating A Bar Chart if ARGV.size==0 || ARGV.include?("2") p = Axlsx::Package.new p.workbook.add_worksheet do |sheet| + sheet.add_row ["A Simple Bar Chart"] sheet.add_row ["First", "Second", "Third"] sheet.add_row [1, 2, 3] - sheet.add_chart(Axlsx::Bar3DChart, :start_at => [0,2], :end_at => [5, 15], :title=>"example 2: Chart") do |chart| - chart.add_series :data=>sheet.rows.last.cells, :labels=> sheet.rows.first.cells + sheet.add_chart(Axlsx::Bar3DChart, :start_at => "A4", :end_at => "F17", :title=>sheet["A1"]) do |chart| + chart.add_series :data => sheet["A3:C3"], :labels => sheet["A2:C2"] end end p.serialize("example2.xlsx") + end #Generating A Pie Chart if ARGV.size==0 || ARGV.include?("3") p = Axlsx::Package.new p.workbook.add_worksheet do |sheet| - sheet.add_row ["First", "Second", "Third"] - sheet.add_row [1, 2, 3] + sheet.add_row ["First", "Second", "Third", "Fourth"] + sheet.add_row [1, 2, 3, "=PRODUCT(A2:C2)"] sheet.add_chart(Axlsx::Pie3DChart, :start_at => [0,2], :end_at => [5, 15], :title=>"example 3: Pie Chart") do |chart| - chart.add_series :data=>sheet.rows.last.cells, :labels=> sheet.rows.first.cells + chart.add_series :data => sheet["A2:D2"], :labels => sheet["A1:D1"] end end p.serialize("example3.xlsx") + end #Using Custom Styles if ARGV.size==0 || ARGV.include?("4") p = Axlsx::Package.new wb = p.workbook - black_cell = wb.styles.add_style :bg_color => "FF000000", :fg_color => "FFFFFFFF", :sz=>14, :alignment => { :horizontal=> :center } - blue_cell = wb.styles.add_style :bg_color => "FF0000FF", :fg_color => "FFFFFFFF", :sz=>14, :alignment => { :horizontal=> :center } + black_cell = wb.styles.add_style :bg_color => "00", :fg_color => "FF", :sz=>14, :alignment => { :horizontal=> :center } + blue_cell = wb.styles.add_style :bg_color => "0000FF", :fg_color => "FF", :sz=>14, :alignment => { :horizontal=> :center } wb.add_worksheet do |sheet| sheet.add_row ["Text Autowidth", "Second", "Third"], :style => [black_cell, blue_cell, black_cell] sheet.add_row [1, 2, 3], :style => Axlsx::STYLE_THIN_BORDER end p.serialize("example4.xlsx") + end #Using Custom Formatting and date1904 if ARGV.size==0 || ARGV.include?("5") p = Axlsx::Package.new @@ -78,10 +82,11 @@ end p.validate.each do |error| puts error.inspect end + end #Generating A Line Chart if ARGV.size==0 || ARGV.include?("7") p = Axlsx::Package.new @@ -89,30 +94,33 @@ sheet.add_row ["First", 1, 5, 7, 9] sheet.add_row ["Second", 5, 2, 14, 9] sheet.add_chart(Axlsx::Line3DChart, :title=>"example 6: Line Chart") do |chart| chart.start_at 0, 2 chart.end_at 10, 15 - chart.add_series :data=>sheet.rows.first.cells[(1..-1)], :title=> sheet.rows.first.cells.first + chart.add_series :data=>["B1:E1"], :title=> sheet["A1"] chart.add_series :data=>sheet.rows.last.cells[(1..-1)], :title=> sheet.rows.last.cells.first end end p.serialize("example7.xlsx") + end + #Add an Image if ARGV.size==0 || ARGV.include?("8") p = Axlsx::Package.new p.workbook.add_worksheet do |sheet| img = File.expand_path('examples/image1.jpeg') - sheet.add_image(:image_src => img) do |image| + sheet.add_image(:image_src => img, :noSelect=>true, :noMove=>true) do |image| image.width=720 image.height=666 image.start_at 2, 2 end end p.serialize("example8.xlsx") + end #Asian Language Support if ARGV.size==0 || ARGV.include?("9") @@ -121,55 +129,74 @@ sheet.add_row ["日本語"] sheet.add_row ["华语/華語"] sheet.add_row ["한국어/조선말"] end p.serialize("example9.xlsx") + end #Styling Columns if ARGV.size==0 || ARGV.include?("10") + p = Axlsx::Package.new percent = p.workbook.styles.add_style :num_fmt => 9 p.workbook.add_worksheet do |sheet| sheet.add_row ['col 1', 'col 2', 'col 3', 'col 4'] sheet.add_row [1, 2, 0.3, 4] sheet.add_row [1, 2, 0.2, 4] sheet.add_row [1, 2, 0.1, 4] end p.workbook.worksheets.first.col_style 2, percent, :row_offset=>1 p.serialize("example10.xlsx") + end #Styling Rows if ARGV.size==0 || ARGV.include?("11") + p = Axlsx::Package.new p.workbook.add_worksheet do |sheet| sheet.add_row ['col 1', 'col 2', 'col 3', 'col 4'] sheet.add_row [1, 2, 0.3, 4] sheet.add_row [1, 2, 0.2, 4] sheet.add_row [1, 2, 0.1, 4] end - head = p.workbook.styles.add_style :bg_color => "FF000000", :fg_color=>"FFFFFFFF" + head = p.workbook.styles.add_style :bg_color => "00", :fg_color=>"FF" percent = p.workbook.styles.add_style :num_fmt => 9 p.workbook.worksheets.first.col_style 2, percent, :row_offset=>1 p.workbook.worksheets.first.row_style 0, head p.serialize("example11.xlsx") + end -#Rails 3 - - # class MyModel < ActiveRecord::Base - # acts_as_axlsx - # end - # - # class MyModelController < ApplicationController - # - # GET /posts/xlsx - # def xlsx - # p = Post.to_xlsx - # p.serialize('posts.xlsx') - # send_file 'posts.xlsx', :type=>"application/xlsx", :x_sendfile=>true - # end +#Using formula +if ARGV.size==0 || ARGV.include?("12") + + p = Axlsx::Package.new + p.workbook.add_worksheet do |sheet| + sheet.add_row ['col 1', 'col 2', 'col 3', 'col 4'] + sheet.add_row [1, 2, 3, "=SUM(A2:C2)"] + end + p.serialize("example12.xlsx") + +end + + +#Using cell specific styling and range / name based access +if ARGV.size==0 || ARGV.include?("13") + + p = Axlsx::Package.new + p.workbook.add_worksheet(:name=>'My Worksheet') do |sheet| + # cell level style overides when adding cells + sheet.add_row ['col 1', 'col 2', 'col 3', 'col 4'], :sz => 16 + sheet.add_row [1, 2, 3, "=SUM(A2:C2)"] + # cell level style overrides via sheet range + sheet["A1:D1"].each { |c| c.color = "FF0000"} + end + p.workbook['My Worksheet!A1:D2'].each { |c| c.style = Axlsx::STYLE_THIN_BORDER } + p.serialize("example13.xlsx") + +end