xlnt - community edition
worksheet.hpp
1 // Copyright (c) 2014-2022 Thomas Fussell
2 // Copyright (c) 2010-2015 openpyxl
3 // Copyright (c) 2024-2025 xlnt-community
4 //
5 // Permission is hereby granted, free of charge, to any person obtaining a copy
6 // of this software and associated documentation files (the "Software"), to deal
7 // in the Software without restriction, including without limitation the rights
8 // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9 // copies of the Software, and to permit persons to whom the Software is
10 // furnished to do so, subject to the following conditions:
11 //
12 // The above copyright notice and this permission notice shall be included in
13 // all copies or substantial portions of the Software.
14 //
15 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18 // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20 // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
21 // THE SOFTWARE
22 //
23 // @license: http://www.opensource.org/licenses/mit-license.php
24 // @author: see AUTHORS file
25 
26 #pragma once
27 
28 #include <iterator>
29 #include <string>
30 #include <vector>
31 
32 #include <xlnt/xlnt_config.hpp>
33 #include <xlnt/cell/index_types.hpp>
34 #include <xlnt/packaging/relationship.hpp>
35 #include <xlnt/worksheet/page_margins.hpp>
36 #include <xlnt/worksheet/page_setup.hpp>
37 #include <xlnt/worksheet/sheet_view.hpp>
38 
39 namespace xlnt {
40 
41 class cell;
42 class cell_reference;
43 class cell_vector;
44 class column_properties;
45 class comment;
46 class condition;
47 class conditional_format;
48 class const_range_iterator;
49 class footer;
50 class header;
51 class range;
52 class range_iterator;
53 class range_reference;
54 class relationship;
55 class row_properties;
56 class sheet_format_properties;
57 class workbook;
58 class phonetic_pr;
59 
60 struct date;
61 
62 namespace detail {
63 
64 class xlsx_consumer;
65 class xlsx_producer;
66 
67 struct worksheet_impl;
68 
69 } // namespace detail
70 
75 class XLNT_API worksheet
76 {
77 public:
82 
87 
91  using reverse_iterator = std::reverse_iterator<iterator>;
92 
96  using const_reverse_iterator = std::reverse_iterator<const_iterator>;
97 
101  worksheet();
102 
106  worksheet(const worksheet &rhs);
107 
111  class workbook workbook();
112 
116  const class workbook workbook() const;
117 
122  void garbage_collect();
123 
124  // identification
125 
130  std::size_t id() const;
131 
136  void id(std::size_t id);
137 
141  std::string title() const;
142 
146  void title(const std::string &title);
147 
148  // freeze panes
149 
153  cell_reference frozen_panes() const;
154 
158  void freeze_panes(cell top_left_cell);
159 
163  void freeze_panes(const cell_reference &top_left_coordinate);
164 
168  void unfreeze_panes();
169 
173  bool has_frozen_panes() const;
174 
175  // container
176 
180  bool has_cell(const cell_reference &reference) const;
181 
186  class cell cell(const cell_reference &reference);
187 
192  const class cell cell(const cell_reference &reference) const;
193 
198  class cell cell(column_t column, row_t row);
199 
204  const class cell cell(column_t column, row_t row) const;
205 
210  class range range(const std::string &reference_string);
211 
216  const class range range(const std::string &reference_string) const;
217 
221  class range range(const range_reference &reference);
222 
226  const class range range(const range_reference &reference) const;
227 
234  class range rows(bool skip_null = true);
235 
242  const class range rows(bool skip_null = true) const;
243 
250  class range columns(bool skip_null = true);
251 
258  const class range columns(bool skip_null = true) const;
259 
260  //TODO: finish implementing cell_iterator wrapping before uncommenting
261  //class cell_vector cells(bool skip_null = true);
262 
263  //TODO: finish implementing cell_iterator wrapping before uncommenting
264  //const class cell_vector cells(bool skip_null = true) const;
265 
269  void clear_cell(const cell_reference &ref);
270 
274  void clear_row(row_t row);
275 
279  void insert_rows(row_t row, std::uint32_t amount);
280 
284  void insert_columns(column_t column, std::uint32_t amount);
285 
289  void delete_rows(row_t row, std::uint32_t amount);
290 
294  void delete_columns(column_t column, std::uint32_t amount);
295 
296  // properties
297 
301  xlnt::column_properties &column_properties(column_t column);
302 
306  const xlnt::column_properties &column_properties(column_t column) const;
307 
311  bool has_column_properties(column_t column) const;
312 
316  void add_column_properties(column_t column, const class column_properties &props);
317 
322  double column_width(column_t column) const;
323 
328 
332  const xlnt::row_properties &row_properties(row_t row) const;
333 
337  bool has_row_properties(row_t row) const;
338 
342  void add_row_properties(row_t row, const class row_properties &props);
343 
348  double row_height(row_t row) const;
349 
350  // positioning
351 
355  cell_reference point_pos(int left, int top) const;
356 
357  // named range
358 
362  void create_named_range(const std::string &name, const std::string &reference_string);
363 
367  void create_named_range(const std::string &name, const range_reference &reference);
368 
372  bool has_named_range(const std::string &name) const;
373 
378  class range named_range(const std::string &name);
379 
384  const class range named_range(const std::string &name) const;
385 
389  void remove_named_range(const std::string &name);
390 
391  // extents
392 
396  row_t lowest_row() const;
397 
401  row_t lowest_row_or_props() const;
402 
406  row_t highest_row() const;
407 
411  row_t highest_row_or_props() const;
412 
416  row_t next_row() const;
417 
421  column_t lowest_column() const;
422 
426  column_t lowest_column_or_props() const;
427 
431  column_t highest_column() const;
432 
436  column_t highest_column_or_props() const;
437 
444  range_reference calculate_dimension(bool skip_null=true, bool skip_row_props=false) const;
445 
446  // cell merge
447 
451  void merge_cells(const std::string &reference_string);
452 
456  void merge_cells(const range_reference &reference);
457 
461  void unmerge_cells(const std::string &reference_string);
462 
466  void unmerge_cells(const range_reference &reference);
467 
471  std::vector<range_reference> merged_ranges() const;
472 
473  // operators
474 
478  bool operator==(const worksheet &other) const;
479 
483  bool operator!=(const worksheet &other) const;
484 
488  bool operator==(std::nullptr_t) const;
489 
493  bool operator!=(std::nullptr_t) const;
494 
498  void operator=(const worksheet &other);
499 
503  class cell operator[](const cell_reference &reference);
504 
508  const class cell operator[](const cell_reference &reference) const;
509 
515  bool compare(const worksheet &other, bool compare_by_reference) const;
516 
517  // page
518 
522  bool has_page_setup() const;
523 
528 
532  void page_setup(const struct page_setup &setup);
533 
537  bool has_page_margins() const;
538 
543 
547  void page_margins(const class page_margins &margins);
548 
549  // auto filter
550 
554  range_reference auto_filter() const;
555 
559  void auto_filter(const std::string &range_string);
560 
564  void auto_filter(const xlnt::range &range);
565 
569  void auto_filter(const range_reference &reference);
570 
574  void clear_auto_filter();
575 
579  bool has_auto_filter() const;
580 
585  void reserve(std::size_t n);
586 
590  bool has_phonetic_properties() const;
591 
595  const phonetic_pr &phonetic_properties() const;
596 
600  void phonetic_properties(const phonetic_pr &phonetic_props);
601 
605  bool has_header_footer() const;
606 
610  class header_footer header_footer() const;
611 
615  void header_footer(const class header_footer &new_header_footer);
616 
621 
625  void sheet_state(xlnt::sheet_state state);
626 
630  iterator begin();
631 
635  iterator end();
636 
640  const_iterator begin() const;
641 
645  const_iterator end() const;
646 
650  const_iterator cbegin() const;
651 
655  const_iterator cend() const;
656 
660  void print_title_rows(row_t start, row_t end);
661 
665  optional<std::pair<row_t, row_t>> print_title_rows() const;
666 
670  void print_title_cols(column_t start, column_t end);
671 
675  optional<std::pair<column_t, column_t>> print_title_cols() const;
676 
680  bool has_print_titles() const;
681 
685  void clear_print_titles();
686 
690  void print_area(const std::string &print_area);
691 
695  void clear_print_area();
696 
700  range_reference print_area() const;
701 
705  bool has_print_area() const;
706 
710  bool has_view() const;
711 
715  sheet_view &view(std::size_t index = 0) const;
716 
720  void add_view(const sheet_view &new_view);
721 
725  void active_cell(const cell_reference &ref);
726 
730  bool has_active_cell() const;
731 
735  cell_reference active_cell() const;
736 
737  // page breaks
738 
743  void clear_page_breaks();
744 
748  const std::vector<row_t> &page_break_rows() const;
749 
753  void page_break_at_row(row_t row);
754 
758  const std::vector<column_t> &page_break_columns() const;
759 
763  void page_break_at_column(column_t column);
764 
768  xlnt::conditional_format conditional_format(const range_reference &ref, const condition &when);
769 
773  xlnt::path path() const;
774 
778  relationship referring_relationship() const;
779 
783  sheet_format_properties format_properties() const;
784 
788  void format_properties(const sheet_format_properties &properties);
789 
793  bool has_drawing() const;
794 
799  bool is_empty() const;
800 
801 private:
802  friend class cell;
803  friend class const_range_iterator;
804  friend class range_iterator;
805  friend class workbook;
806  friend class detail::xlsx_consumer;
807  friend class detail::xlsx_producer;
808 
812  worksheet(detail::worksheet_impl *d);
813 
817  void register_comments_in_manifest();
818 
822  void register_calc_chain_in_manifest();
823 
827  void garbage_collect_formulae();
828 
832  void parent(class workbook &wb);
833 
838  void move_cells(std::uint32_t index, std::uint32_t amount, row_or_col_t row_or_col, bool reverse = false);
839 
843  detail::worksheet_impl *d_ = nullptr;
844 };
845 
846 } // namespace xlnt
A range is a 2D collection of cells with defined extens that can be iterated upon.
Definition: range.hpp:53
A const version of range_iterator which does not allow modification to the dereferenced cell_vector...
Definition: range_iterator.hpp:163
Represents an association between a source Package or part, and a target object which can be a part o...
Definition: relationship.hpp:103
std::uint32_t row_t
All rows should be referred to by an instance of this type.
Definition: index_types.hpp:40
Definition: cell_reference.hpp:261
Describes the margins around a worksheet for printing.
Definition: page_margins.hpp:35
Enumerates the possible types a cell can be determined by it&#39;s current value.
Definition: cell.hpp:36
Describes a conditional format that will be applied to all cells in the associated range that satisfy...
Definition: conditional_format.hpp:90
The properties of a row in a worksheet.
Definition: row_properties.hpp:38
A worksheet is a 2D array of cells starting with cell A1 in the top-left corner and extending indefin...
Definition: worksheet.hpp:75
An object used to refer to a cell. References have two parts, the column and the row. In Excel, the reference string A1 refers to the top-left-most cell. A cell_reference can be initialized from a string of this form or a 1-indexed ordered pair of the form column, row.
Definition: cell_reference.hpp:59
Describes a unit of data in a worksheet at a specific coordinate and its associated properties...
Definition: cell.hpp:83
sheet_state
Defines how a worksheet appears in the workbook. A workbook must have at least one sheet which is vis...
Definition: page_setup.hpp:75
Describes a view of a worksheet. Worksheets can have multiple views which show the data differently...
Definition: sheet_view.hpp:49
std::reverse_iterator< const_iterator > const_reverse_iterator
Iterate in reverse order over a const worksheet with an iterator of this type.
Definition: worksheet.hpp:96
value is an ISO 8601 formatted date
Encapsulates a path that points to location in a filesystem.
Definition: path.hpp:43
Many settings in xlnt are allowed to not have a value set. This class encapsulates a value which may ...
Definition: format.hpp:43
An iterator used by worksheet and range for traversing a 2D grid of cells by row/column then across t...
Definition: range_iterator.hpp:43
Columns can be referred to as a string A,B,...Z,AA,AB,..,ZZ,AAA,...,ZZZ or as a 1-indexed index...
Definition: index_types.hpp:47
A 2D range of cells in a worksheet that is referred to by name. ws->range("A1:B2") could be replaced ...
Definition: named_range.hpp:42
Describes how a worksheet will be converted into a page during printing.
Definition: page_setup.hpp:85
General worksheet formatting properties.
Definition: sheet_format_properties.hpp:36
Properties applied to a column in a worksheet. Columns can have a size and a style.
Definition: column_properties.hpp:39
std::reverse_iterator< iterator > reverse_iterator
Iterate in reverse over a non-const worksheet with an iterator of this type.
Definition: worksheet.hpp:91
A range_reference describes a rectangular area of a worksheet with positive width and height defined ...
Definition: range_reference.hpp:36
workbook is the container for all other parts of the document.
Definition: workbook.hpp:96
Phonetic properties Element provides a collection of properties that affect display of East Asian Lan...
Definition: phonetic_pr.hpp:39