Class: Rspreadsheet::Worksheet
- Inherits:
-
Object
- Object
- Rspreadsheet::Worksheet
show all
- Defined in:
- lib/rspreadsheet/worksheet.rb
Instance Attribute Summary collapse
XMLTiedArray related methods
collapse
XMLTiedArray_WithRepeatableItems connected methods
collapse
How to get to cells? (syntactic sugar)
collapse
Constructor Details
#initialize(xmlnode_or_sheet_name, workbook) ⇒ Worksheet
workbook is here ONLY because of inserting images - to find unique name - it would be much better if it should bot be there
20
21
22
23
24
25
26
27
28
29
30
31
|
# File 'lib/rspreadsheet/worksheet.rb', line 20
def initialize(xmlnode_or_sheet_name,workbook) initialize_xml_tied_array
case xmlnode_or_sheet_name
when LibXML::XML::Node
@xmlnode = xmlnode_or_sheet_name
when String
@xmlnode = Tools.prepare_ns_node('table','table')
self.name = xmlnode_or_sheet_name
else raise 'Provide name or xml node to create a Worksheet object'
end
end
|
Dynamic Method Handling
This class handles dynamic methods through the method_missing method
#method_missing(method_name, *args, &block) ⇒ Object
Allows syntax like sheet.F15. TO catch errors easier, allows only up to three uppercase letters in colum part, althought it won't be necessarry to restrict.
120
121
122
123
124
125
126
127
128
129
130
131
132
|
# File 'lib/rspreadsheet/worksheet.rb', line 120
def method_missing method_name, *args, &block
if method_name.to_s.match(/^([A-Z]{1,3})(\d{1,8})(=?)$/)
row,col = Rspreadsheet::Tools.convert_cell_address_to_coordinates($~[1],$~[2])
assignchar = $~[3]
if assignchar == '='
self.cells(row,col).value = args.first
else
self.cells(row,col).value
end
else
super
end
end
|
Instance Attribute Details
#xmlnode ⇒ Object
Returns the value of attribute xmlnode.
12
13
14
|
# File 'lib/rspreadsheet/worksheet.rb', line 12
def xmlnode
@xmlnode
end
|
Instance Method Details
#[](*params) ⇒ Object
Returns value of the cell given either by row,column integer coordinates of by address.
87
88
89
|
# File 'lib/rspreadsheet/worksheet.rb', line 87
def [](*params)
cells(*params).andand.value
end
|
#[]=(*params) ⇒ Object
Sets value of the cell given either by row,column integer coordinates of by address.
It also sets the type of the cell according to type of the value. For details #see Cell.value=
This also allows syntax like
@sheet[1] = ['Jan', 'Feb', 'Mar']
95
96
97
98
99
100
101
|
# File 'lib/rspreadsheet/worksheet.rb', line 95
def []=(*params)
if (params.size == 2) and params[0].kind_of?(Integer)
rows(params[0]).cellvalues = params[1]
else
cells(*params[0..-2]).andand.value = params.last
end
end
|
#add_row_above(arowi) ⇒ Object
42
43
44
|
# File 'lib/rspreadsheet/worksheet.rb', line 42
def add_row_above(arowi)
insert_new_empty_subitem_before(arowi)
end
|
#cells(*params) ⇒ Object
Also known as:
cell
Returns a Cell object placed in row and column or on a Cell on string address
104
105
106
107
108
109
110
111
112
113
|
# File 'lib/rspreadsheet/worksheet.rb', line 104
def cells(*params)
case params.length
when 0 then raise 'Not implemented yet' when 1..2
r,c = Rspreadsheet::Tools.a2c(*params)
arow = row(r)
arow.andand.cell(c)
else raise ArgumentError.new('Wrong number of arguments.')
end
end
|
#column(param) ⇒ Object
115
116
117
118
|
# File 'lib/rspreadsheet/worksheet.rb', line 115
def column(param)
_,coli = Rspreadsheet::Tools.a2c(1,param)
Column.new(self,coli)
end
|
#detach_row_in_xml(rowi) ⇒ Object
51
52
53
|
# File 'lib/rspreadsheet/worksheet.rb', line 51
def detach_row_in_xml(rowi)
return detach_my_subnode_respect_repeated(rowi)
end
|
#first_unused_row_index ⇒ Object
38
39
40
|
# File 'lib/rspreadsheet/worksheet.rb', line 38
def first_unused_row_index
first_unused_subitem_index
end
|
#images(*params) ⇒ Object
66
67
68
|
# File 'lib/rspreadsheet/worksheet.rb', line 66
def images(*params)
worksheet_images.subitems(*params)
end
|
#images_count ⇒ Object
63
64
65
|
# File 'lib/rspreadsheet/worksheet.rb', line 63
def images_count
worksheet_images.size
end
|
#insert_cell_before(arowi, acoli) ⇒ Object
TODO: maybe move this to row level
46
47
48
49
|
# File 'lib/rspreadsheet/worksheet.rb', line 46
def insert_cell_before(arowi,acoli) detach_row_in_xml(arowi)
rows(arowi).insert_new_item(acoli)
end
|
#insert_image(filename, mime = 'image/png') ⇒ Object
69
70
71
|
# File 'lib/rspreadsheet/worksheet.rb', line 69
def insert_image(filename,mime='image/png')
worksheet_images.insert_image(filename,mime)
end
|
#insert_image_to(x, y, filename, mime = 'image/png') ⇒ Object
72
73
74
75
76
|
# File 'lib/rspreadsheet/worksheet.rb', line 72
def insert_image_to(x,y,filename,mime='image/png')
img = insert_image(filename,mime)
img.move_to(x,y)
img
end
|
#name=(value) ⇒ Object
36
|
# File 'lib/rspreadsheet/worksheet.rb', line 36
def name=(value); Tools.set_ns_attribute(@xmlnode,'table','name', value) end
|
#nonemptycells ⇒ Object
55
56
57
|
# File 'lib/rspreadsheet/worksheet.rb', line 55
def nonemptycells
used_rows_range.collect{ |rowi| rows(rowi).nonemptycells }.flatten
end
|
#prepare_subitem(rowi) ⇒ Object
81
|
# File 'lib/rspreadsheet/worksheet.rb', line 81
def prepare_subitem(rowi); Row.new(self,rowi) end
|
#rowcache ⇒ Object
82
|
# File 'lib/rspreadsheet/worksheet.rb', line 82
def rowcache; @itemcache end
|
#rows(*params) ⇒ Object
Also known as:
row
79
|
# File 'lib/rspreadsheet/worksheet.rb', line 79
def rows(*params); subitems(*params) end
|
#subnode_options ⇒ Object
14
15
16
17
18
|
# File 'lib/rspreadsheet/worksheet.rb', line 14
def subnode_options; {
:node_name => 'table-row',
:ignore_groupings => ['table-header-rows'],
:repeated_attribute => 'number-rows-repeated'
} end
|
#used_rows_range ⇒ Object
134
135
136
|
# File 'lib/rspreadsheet/worksheet.rb', line 134
def used_rows_range
1..self.rowcount
end
|
#worksheet_images ⇒ Object
60
61
62
|
# File 'lib/rspreadsheet/worksheet.rb', line 60
def worksheet_images
@worksheet_images ||= WorksheetImages.new(self)
end
|