Class: RubyXL::Cell

Inherits:
OOXMLObject show all
Includes:
LegacyCell
Defined in:
lib/rubyXL/objects/sheet_data.rb

Overview

Instance Attribute Summary

Attributes included from LegacyCell

#formula, #worksheet

Instance Method Summary collapse

Methods included from LegacyCell

#border_bottom, #border_diagonal, #border_left, #border_right, #border_top, #change_border, #change_border_bottom, #change_border_diagonal, #change_border_left, #change_border_right, #change_border_top, #change_contents, #change_fill, #change_font_bold, #change_font_color, #change_font_italics, #change_font_name, #change_font_size, #change_font_strikethrough, #change_font_underline, #change_horizontal_alignment, #change_text_wrap, #change_vertical_alignment, #fill_color, #font_color, #font_name, #font_size, #font_switch, #horizontal_alignment, #inspect, #is_bolded, #is_italicized, #is_struckthrough, #is_underlined, #text_wrap, #vertical_alignment, #workbook

Methods included from OOXMLObjectInstanceMethods

#==, #before_write_xml, included, #initialize, #write_xml

Instance Method Details

#columnObject



46
47
48
# File 'lib/rubyXL/objects/sheet_data.rb', line 46

def column
  r && r.first_col
end

#column=(v) ⇒ Object



50
51
52
# File 'lib/rubyXL/objects/sheet_data.rb', line 50

def column=(v)
  self.r = RubyXL::Reference.new(row || 0, v)
end

#index_in_collectionObject



34
35
36
# File 'lib/rubyXL/objects/sheet_data.rb', line 34

def index_in_collection
  r.col_range.begin
end

#is_date?Boolean

Returns:

  • (Boolean)


67
68
69
70
71
# File 'lib/rubyXL/objects/sheet_data.rb', line 67

def is_date?
  return false unless raw_value =~ /\A\d+(?:\.\d+)?\Z/ # Only fully numeric values can be dates
  num_fmt = self.number_format
  num_fmt && num_fmt.is_date_format?
end

#number_formatObject



63
64
65
# File 'lib/rubyXL/objects/sheet_data.rb', line 63

def number_format
  workbook.stylesheet.get_number_format_by_id(get_cell_xf.num_fmt_id)
end

#raw_valueObject



54
55
56
# File 'lib/rubyXL/objects/sheet_data.rb', line 54

def raw_value
  value_container && value_container.value
end

#raw_value=(v) ⇒ Object



58
59
60
61
# File 'lib/rubyXL/objects/sheet_data.rb', line 58

def raw_value=(v)
  self.value_container ||= RubyXL::CellValue.new
  value_container.value = v
end

#rowObject



38
39
40
# File 'lib/rubyXL/objects/sheet_data.rb', line 38

def row
  r && r.first_row
end

#row=(v) ⇒ Object



42
43
44
# File 'lib/rubyXL/objects/sheet_data.rb', line 42

def row=(v)
  self.r = RubyXL::Reference.new(v, column || 0)
end

#value(args = {}) ⇒ Object

Gets massaged value of the cell, converting datatypes to those known to Ruby (that includes stripping any special formatting from RichText).



75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
# File 'lib/rubyXL/objects/sheet_data.rb', line 75

def value(args = {})
  return raw_value if args[:raw]
  case datatype
  when RubyXL::DataType::SHARED_STRING then
    workbook.shared_strings_container[raw_value.to_i].to_s
  else
    if is_date? then workbook.num_to_date(raw_value.to_f)
    elsif raw_value.is_a?(String) && (raw_value =~ /\A-?\d+(\.\d+(?:e[+-]\d+)?)?\Z/i) # Numeric
      if $1 then raw_value.to_f
      else raw_value.to_i
      end
    else raw_value
    end
  end
end