xlnt - community edition
workbook.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 <cstdint>
29 #include <functional>
30 #include <iterator>
31 #include <memory>
32 #include <string>
33 #include <unordered_map>
34 #include <vector>
35 
36 #include <xlnt/xlnt_config.hpp>
37 #include <xlnt/internal/features.hpp>
38 
39 #if XLNT_HAS_INCLUDE(<string_view>) && XLNT_HAS_FEATURE(U8_STRING_VIEW)
40  #include <string_view>
41 #endif
42 
43 namespace xlnt {
44 
45 enum class calendar;
46 enum class core_property;
47 enum class extended_property;
48 enum class relationship_type;
49 
50 class alignment;
51 class border;
52 class calculation_properties;
53 class cell;
54 class cell_style;
55 class color;
56 class const_worksheet_iterator;
57 class fill;
58 class font;
59 class format;
60 class rich_text;
61 class manifest;
62 class metadata_property;
63 class named_range;
64 class number_format;
65 class path;
66 class pattern_fill;
67 class protection;
68 class range;
69 class range_reference;
70 class relationship;
71 class streaming_workbook_reader;
72 class style;
73 class style_serializer;
74 class theme;
75 class variant;
76 class workbook_view;
77 class worksheet;
78 class worksheet_iterator;
79 class zip_file;
80 
81 struct datetime;
82 
83 namespace detail {
84 
85 struct stylesheet;
86 struct workbook_impl;
87 struct worksheet_impl;
88 class xlsx_consumer;
89 class xlsx_producer;
90 
91 } // namespace detail
92 
96 class XLNT_API workbook
97 {
98 public:
102  enum class clone_method
103  {
104  deep_copy,
105  shallow_copy
106  };
107 
113 
119 
125  using reverse_iterator = std::reverse_iterator<iterator>;
126 
132  using const_reverse_iterator = std::reverse_iterator<const_iterator>;
133 
138  static workbook empty();
139 
140  // Constructors
141 
146  workbook();
147 
151  workbook(const xlnt::path &file);
152 
156  workbook(const xlnt::path &file, const std::string &password);
157 
158 #if XLNT_HAS_FEATURE(U8_STRING_VIEW)
159  workbook(const xlnt::path &file, std::u8string_view password);
163 #endif
164 
168  workbook(std::istream &data);
169 
173  workbook(std::istream &data, const std::string &password);
174 
175 #if XLNT_HAS_FEATURE(U8_STRING_VIEW)
176  workbook(std::istream &data, std::u8string_view password);
180 #endif
181 
185  workbook(workbook &&other) = default;
186 
191  workbook(const workbook &other) = default;
192 
198  ~workbook() = default;
199 
204  workbook clone(clone_method method) const;
205 
206  // Worksheets
207 
211  worksheet create_sheet();
212 
216  worksheet create_sheet(std::size_t index);
217 
221  worksheet create_sheet_with_rel(const std::string &title, const relationship &rel);
222 
227  worksheet copy_sheet(worksheet worksheet);
228 
233  worksheet copy_sheet(worksheet worksheet, std::size_t index);
234 
239  worksheet active_sheet();
240 
245  void active_sheet(std::size_t index);
246 
252  worksheet sheet_by_title(const std::string &title);
253 
259  const worksheet sheet_by_title(const std::string &title) const;
260 
265  worksheet sheet_by_index(std::size_t index);
266 
271  const worksheet sheet_by_index(std::size_t index) const;
272 
277  worksheet sheet_by_id(std::size_t id);
278 
283  const worksheet sheet_by_id(std::size_t id) const;
284 
290  bool sheet_hidden_by_index(std::size_t index) const;
291 
295  bool contains(const std::string &title) const;
296 
300  std::size_t index(worksheet worksheet);
301 
302  // remove worksheets
303 
307  void remove_sheet(worksheet worksheet);
308 
313  void clear();
314 
315  // iterators
316 
320  iterator begin();
321 
327  iterator end();
328 
332  const_iterator begin() const;
333 
339  const_iterator end() const;
340 
344  const_iterator cbegin() const;
345 
351  const_iterator cend() const;
352 
356  void apply_to_cells(std::function<void(cell)> f);
357 
362  std::vector<std::string> sheet_titles() const;
363 
367  std::size_t sheet_count() const;
368 
369  // Metadata Properties
370 
374  bool has_core_property(xlnt::core_property type) const;
375 
380  std::vector<xlnt::core_property> core_properties() const;
381 
386 
390  void core_property(xlnt::core_property type, const variant &value);
391 
395  bool has_extended_property(xlnt::extended_property type) const;
396 
401  std::vector<xlnt::extended_property> extended_properties() const;
402 
407 
411  void extended_property(xlnt::extended_property type, const variant &value);
412 
416  bool has_custom_property(const std::string &property_name) const;
417 
422  std::vector<std::string> custom_properties() const;
423 
427  variant custom_property(const std::string &property_name) const;
428 
432  void custom_property(const std::string &property_name, const variant &value);
433 
439  calendar base_date() const;
440 
445  void base_date(calendar base_date);
446 
450  bool has_title() const;
451 
455  std::string title() const;
456 
460  void title(const std::string &title);
461 
465  void abs_path(const std::string &path);
466 
470  void arch_id_flags(const std::size_t flags);
471 
472  // Named Ranges
473 
477  std::vector<xlnt::named_range> named_ranges() const;
478 
482  void create_named_range(const std::string &name, worksheet worksheet, const range_reference &reference);
483 
487  void create_named_range(const std::string &name, worksheet worksheet, const std::string &reference_string);
488 
492  bool has_named_range(const std::string &name) const;
493 
497  class range named_range(const std::string &name);
498 
502  void remove_named_range(const std::string &name);
503 
504  // Serialization/Deserialization
505 
510  void save(std::vector<std::uint8_t> &data) const;
511 
516  void save(std::vector<std::uint8_t> &data, const std::string &password) const;
517 
518 #if XLNT_HAS_FEATURE(U8_STRING_VIEW)
519  void save(std::vector<std::uint8_t> &data, std::u8string_view password) const;
524 #endif
525 
530  void save(const std::string &filename) const;
531 
536  void save(const std::string &filename, const std::string &password) const;
537 
538 #if XLNT_HAS_FEATURE(U8_STRING_VIEW)
539  void save(std::u8string_view filename) const;
544 
549  void save(std::u8string_view filename, std::u8string_view password) const;
550 #endif
551 
552 #ifdef _MSC_VER
553  void save(const std::wstring &filename) const;
558 
563  void save(const std::wstring &filename, const std::string &password) const;
564 #endif
565 
570  void save(const xlnt::path &filename) const;
571 
576  void save(const xlnt::path &filename, const std::string &password) const;
577 
578 #if XLNT_HAS_FEATURE(U8_STRING_VIEW)
579  void save(const xlnt::path &filename, std::u8string_view password) const;
584 #endif
585 
589  void save(std::ostream &stream) const;
590 
595  void save(std::ostream &stream, const std::string &password) const;
596 
597 #if XLNT_HAS_FEATURE(U8_STRING_VIEW)
598  void save(std::ostream &stream, std::u8string_view password) const;
603 #endif
604 
609  void load(const std::vector<std::uint8_t> &data);
610 
615  void load(const std::vector<std::uint8_t> &data, const std::string &password);
616 
617 #if XLNT_HAS_FEATURE(U8_STRING_VIEW)
618  void load(const std::vector<std::uint8_t> &data, std::u8string_view password);
623 #endif
624 
629  void load(const std::string &filename);
630 
635  void load(const std::string &filename, const std::string &password);
636 
637 #if XLNT_HAS_FEATURE(U8_STRING_VIEW)
638  void load(std::u8string_view filename);
643 
648  void load(std::u8string_view filename, std::u8string_view password);
649 #endif
650 
651 
652 #ifdef _MSC_VER
653  void load(const std::wstring &filename);
658 
663  void load(const std::wstring &filename, const std::string &password);
664 #endif
665 
670  void load(const xlnt::path &filename);
671 
676  void load(const xlnt::path &filename, const std::string &password);
677 
678 #if XLNT_HAS_FEATURE(U8_STRING_VIEW)
679  void load(const xlnt::path &filename, std::u8string_view password);
684 #endif
685 
690  void load(std::istream &stream);
691 
696  void load(std::istream &stream, const std::string &password);
697 
698 #if XLNT_HAS_FEATURE(U8_STRING_VIEW)
699  void load(std::istream &stream, std::u8string_view password);
704 #endif
705 
706  // View
707 
711  bool has_view() const;
712 
716  workbook_view view() const;
717 
721  void view(const workbook_view &view);
722 
723  // Properties
724 
728  bool has_code_name() const;
729 
733  std::string code_name() const;
734 
738  void code_name(const std::string &code_name);
739 
743  bool has_file_version() const;
744 
748  std::string app_name() const;
749 
753  std::size_t last_edited() const;
754 
758  std::size_t lowest_edited() const;
759 
763  std::size_t rup_build() const;
764 
765  // Theme
766 
770  bool has_theme() const;
771 
775  const xlnt::theme &theme() const;
776 
780  void theme(const class theme &value);
781 
782  // Formats
783 
788  xlnt::format format(std::size_t format_index);
789 
794  const xlnt::format format(std::size_t format_index) const;
795 
799  xlnt::format create_format(bool default_format = false);
800 
805  void clear_formats();
806 
807  // Styles
808 
812  bool has_style(const std::string &name) const;
813 
817  class style style(const std::string &name);
818 
822  const class style style(const std::string &name) const;
823 
827  class style create_style(const std::string &name);
828 
832  class style create_builtin_style(std::size_t builtin_id);
833 
839  void clear_styles();
840 
844  void default_slicer_style(const std::string &value);
845 
849  std::string default_slicer_style() const;
850 
854  void enable_known_fonts();
855 
859  void disable_known_fonts();
860 
864  bool known_fonts_enabled() const;
865 
866  // Manifest
867 
871  class manifest &manifest();
872 
876  const class manifest &manifest() const;
877 
878  // shared strings
879 
886  std::size_t add_shared_string(const rich_text &shared, bool allow_duplicates = false);
887 
891  const rich_text &shared_strings(std::size_t index) const;
892 
897  std::vector<rich_text> &shared_strings();
898 
903  const std::vector<rich_text> &shared_strings() const;
904 
905  // Thumbnail
906 
911  void thumbnail(const std::vector<std::uint8_t> &thumbnail,
912  const std::string &extension, const std::string &content_type);
913 
917  const std::vector<std::uint8_t> &thumbnail() const;
918 
922  const std::unordered_map<std::string, std::vector<std::uint8_t>>& binaries() const;
923 
924  // Calculation properties
925 
929  bool has_calculation_properties() const;
930 
935 
939  void calculation_properties(const class calculation_properties &props);
940 
946  bool compare(const workbook &other, bool compare_by_reference) const;
947 
948  // Operators
949 
954  workbook &operator=(const workbook &other) = default;
955 
960  workbook &operator=(workbook &&other) = default;
961 
965  worksheet operator[](const std::string &name);
966 
970  worksheet operator[](std::size_t index);
971 
976  bool operator==(const workbook &rhs) const;
977 
982  bool operator!=(const workbook &rhs) const;
983 
984 private:
985  friend class streaming_workbook_reader;
986  friend class worksheet;
987  friend class detail::xlsx_consumer;
988  friend class detail::xlsx_producer;
989  friend struct detail::worksheet_impl;
990 
995  workbook(std::shared_ptr<detail::workbook_impl> impl);
996 
1001  workbook(std::weak_ptr<detail::workbook_impl> impl);
1002 
1006  void set_impl(std::shared_ptr<detail::workbook_impl> impl);
1007 
1011  template <typename T>
1012  void construct(const xlnt::path &file, const T &password);
1013 
1017  template <typename T>
1018  void construct(std::istream &data, const T &password);
1019 
1024  template <typename T>
1025  void save_internal(std::vector<std::uint8_t> &data, const T &password) const;
1026 
1031  template <typename T>
1032  void save_internal(const T &filename) const;
1033 
1038  template <typename T>
1039  void save_internal(const T &filename, const T &password) const;
1040 
1045  template <typename T>
1046  void save_internal(const xlnt::path &filename, const T &password) const;
1047 
1052  template <typename T>
1053  void save_internal(std::ostream &stream, const T &password) const;
1054 
1059  template <typename T>
1060  void load_internal(const std::vector<std::uint8_t> &data, const T &password);
1061 
1066  template <typename T>
1067  void load_internal(const T &filename);
1068 
1073  template <typename T>
1074  void load_internal(const T &filename, const T &password);
1075 
1080  template <typename T>
1081  void load_internal(const xlnt::path &filename, const T &password);
1082 
1087  template <typename T>
1088  void load_internal(std::istream &stream, const T &password);
1089 
1094  detail::workbook_impl &impl();
1095 
1100  const detail::workbook_impl &impl() const;
1101 
1107  void register_package_part(relationship_type type);
1108 
1115  void register_workbook_part(relationship_type type);
1116 
1123  void register_worksheet_part(worksheet ws, relationship_type type);
1124 
1128  void garbage_collect_formulae();
1129 
1133  void update_sheet_properties();
1134 
1138  void swap(workbook &other);
1139 
1143  void reorder_relationships();
1144 
1148  std::shared_ptr<detail::workbook_impl> d_;
1149 };
1150 
1151 } // namespace xlnt
core_property
Every core property in a workbook must be one of these types.
Definition: metadata_property.hpp:34
A range is a 2D collection of cells with defined extens that can be iterated upon.
Definition: range.hpp:53
Represents an association between a source Package or part, and a target object which can be a part o...
Definition: relationship.hpp:103
Represents an object that can have variable type.
Definition: variant.hpp:40
Definition: cell_reference.hpp:261
A workbook can be opened in multiple windows with different views. This class represents a particular...
Definition: workbook_view.hpp:37
Enumerates the possible types a cell can be determined by it&#39;s current value.
Definition: cell.hpp:36
extended_property
Every extended property in a workbook must be one of these types.
Definition: metadata_property.hpp:56
std::reverse_iterator< iterator > reverse_iterator
typedef for the iterator used for iterating through this workbook (non-const) in a range-based for lo...
Definition: workbook.hpp:125
A worksheet is a 2D array of cells starting with cell A1 in the top-left corner and extending indefin...
Definition: worksheet.hpp:75
A theme is a combination of fonts, colors, and effects. This isn&#39;t really supported yet...
Definition: theme.hpp:35
Describes a unit of data in a worksheet at a specific coordinate and its associated properties...
Definition: cell.hpp:83
Encapsulates zero or more formatted text runs where a text run is a string of text with the same defi...
Definition: rich_text.hpp:41
An iterator which is used to iterate over the worksheets in a workbook.
Definition: worksheet_iterator.hpp:44
Encapsulates a path that points to location in a filesystem.
Definition: path.hpp:43
relationship_type
All package relationships must be one of these defined types.
Definition: relationship.hpp:54
Workbook file properties relating to calculations.
Definition: calculation_properties.hpp:36
Describes the formatting of a particular cell.
Definition: format.hpp:57
An iterator which is used to iterate over the worksheets in a const workbook.
Definition: worksheet_iterator.hpp:154
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
workbook is the container for all other parts of the document.
Definition: streaming_workbook_reader.hpp:55
The manifest keeps track of all files in the OOXML package and their type and relationships.
Definition: manifest.hpp:41
A range_reference describes a rectangular area of a worksheet with positive width and height defined ...
Definition: range_reference.hpp:36
Describes a style which has a name and can be applied to multiple individual formats. In Excel this is a "Cell Style".
Definition: style.hpp:55
std::reverse_iterator< const_iterator > const_reverse_iterator
typedef for the iterator used for iterating through this workbook (const) in a range-based for loop i...
Definition: workbook.hpp:132
workbook is the container for all other parts of the document.
Definition: workbook.hpp:96
calendar
An enumeration of possible base dates. Dates in Excel are stored as days since this base date...
Definition: calendar.hpp:35
clone_method
The method for cloning workbooks.
Definition: workbook.hpp:102