Analyzing your prompt, please hold on...
An error occurred while retrieving the results. Please refresh the page and try again.
The default font will automatically change when the region setting is changed.
If the default font is changed, the row height and column width are also changed, and it may even mess up the page layout.
What caused the default font to change?
If Excel theme font is set, Excel will automatically switch between different fonts based on the current language environment.
In Excel, select the Home tab, click on the font dropdown box, and you will see Theme Fonts with two theme fonts: Calibri Light (Headings) and Calibri (Body) at the top when using the English region setting.

If Theme Font is selected, the font name will display differently in different regions.
If you do not want the font to be automatically changed in different regions, don’t select the two Theme Fonts.
With Aspose.Cells for C++, we can check whether the default font is a theme font or set the theme font using the Font.GetSchemeType() property.
The following sample code shows how to manipulate theme font.
#include <iostream>
#include "Aspose.Cells.h"
using namespace Aspose::Cells;
int main()
{
Aspose::Cells::Startup();
// Create a workbook object
Workbook workbook(u"Book1.xlsx");
// Get the default style
Style defaultStyle = workbook.GetDefaultStyle();
// Get the font scheme type
FontSchemeType schemeType = defaultStyle.GetFont().GetSchemeType();
// Check if the font is a theme font
if (schemeType == FontSchemeType::Major || schemeType == FontSchemeType::Minor)
{
std::cout << "It's theme font" << std::endl;
}
// Change theme font to normal font
defaultStyle.GetFont().SetSchemeType(FontSchemeType::None);
// Set the modified default style back to the workbook
workbook.SetDefaultStyle(defaultStyle);
Aspose::Cells::Cleanup();
return 0;
}
Sometimes, our servers and users' machines are not in the same region. How can we obtain the same font that users want for file processing?
We must set the system regional settings before loading the file using the LoadOptions.GetRegion() property.
The following sample code shows how to get the local theme font.
#include <iostream>
#include "Aspose.Cells.h"
using namespace Aspose::Cells;
int main()
{
Aspose::Cells::Startup();
// Instantiate a new LoadOptions
LoadOptions options;
// Set the customer's region to Japan
options.SetRegion(CountryCode::Japan);
// Instantiate a new Workbook with the specified options
Workbook workbook(u"Book1.xlsx", options);
// Get the default style of the workbook
Style defaultStyle = workbook.GetDefaultStyle();
// Get the customer's local font name
U16String localFontName = defaultStyle.GetFont().GetName();
std::cout << "Local Font Name: " << localFontName.ToUtf8() << std::endl;
Aspose::Cells::Cleanup();
return 0;
}
Analyzing your prompt, please hold on...
An error occurred while retrieving the results. Please refresh the page and try again.