mirror of
https://github.com/QtExcel/QXlsx.git
synced 2025-01-16 04:42:53 +08:00
68 lines
1.4 KiB
C++
68 lines
1.4 KiB
C++
// numberformat.cpp
|
|
|
|
// QXlsx
|
|
// MIT License
|
|
// https://github.com/j2doll/QXlsx
|
|
//
|
|
// QtXlsx
|
|
// https://github.com/dbzhang800/QtXlsxWriter
|
|
// http://qtxlsx.debao.me/
|
|
// MIT License
|
|
|
|
#include <QtGui>
|
|
#include "xlsxdocument.h"
|
|
#include "xlsxformat.h"
|
|
|
|
using namespace QXlsx;
|
|
|
|
int numberformat()
|
|
{
|
|
QXlsx::Document xlsx;
|
|
xlsx.setColumnWidth(1, 4, 20.0);
|
|
|
|
QXlsx::Format header;
|
|
header.setFontBold(true);
|
|
header.setFontSize(20);
|
|
|
|
//Custom number formats
|
|
QStringList numFormats;
|
|
numFormats
|
|
<< "Qt #"
|
|
<< "yyyy-mmm-dd"
|
|
<< "$ #,##0.00"
|
|
<< "[red]0.00";
|
|
xlsx.write(1, 1, "Raw data", header);
|
|
xlsx.write(1, 2, "Format", header);
|
|
xlsx.write(1, 3, "Shown value", header);
|
|
for (int i=0; i<numFormats.size(); ++i)
|
|
{
|
|
int row = i+2;
|
|
xlsx.write(row, 1, 100.0);
|
|
xlsx.write(row, 2, numFormats[i]);
|
|
QXlsx::Format format;
|
|
format.setNumberFormat(numFormats[i]);
|
|
xlsx.write(row, 3, 100.0, format);
|
|
}
|
|
|
|
//Builtin number formats
|
|
xlsx.addSheet();
|
|
xlsx.setColumnWidth(1, 4, 20.0);
|
|
xlsx.write(1, 1, "Raw data", header);
|
|
xlsx.write(1, 2, "Builtin Format", header);
|
|
xlsx.write(1, 3, "Shown value", header);
|
|
for (int i=0; i<50; ++i)
|
|
{
|
|
int row = i+2;
|
|
int numFmt = i;
|
|
xlsx.write(row, 1, 100.0);
|
|
xlsx.write(row, 2, numFmt);
|
|
QXlsx::Format format;
|
|
format.setNumberFormatIndex(numFmt);
|
|
xlsx.write(row, 3, 100.0, format);
|
|
}
|
|
|
|
xlsx.saveAs("numberformat.xlsx");
|
|
|
|
return 0;
|
|
}
|