Перейти до основного вмісту

Qt та Excel. Початок


Спроба розібратися з доступом до файлів .xls за допомогою <QtActive>.

.pro

CONFIG += qaxcontainer


.h

#include <ActiveQt/qaxbase.h>
#include <ActiveQt/qaxobject.h>

public:
QAxObject *excel;
QAxObject *wbooks;
QAxObject *book;
QAxObject *sheets;
QAxObject *list;
QAxObject *cell;


.cpp

excel = new QAxObject("Excel.Application", this); // пуск
excel->setProperty("Visible", 0); // робимо його невидимим
excel->setProperty("DisplayAterts", 0); // щоб не лаявся і не ставив запитань
wbooks = excel->querySubObject("Workbooks");
QString fileName(“D:\\Files\\myFile.xls”);
book = wbooks->querySubObject("Open (const QString&)", fileName); відкриваємо файл
sheets = book->querySubObject("Sheets");
list = sheets->querySubObject("Item(QVariant&)", 1); //лист 1.

cell = list->querySubObject("Cells (Int, Int)", 2, 1); // [B:1]
cell->dynamicCall("value", QString("%1").arg(ui.doubleSpinBox->value())); // вставляємо дані з doubleSpinBox.
QString newName(“D:\\Files\\newFile.xls”);

book->dynamicCall("SaveAs(const QString&)", newFile); // зберігаємо в новий файл
// book->dynamicCall("Save()"); // або старий

wbooks->dynamicCall("Close()");
excel->dynamicCall("Quit()");


начебто працює :)

Популярні дописи з цього блогу

QString в HEX и обратно

Спочатку з QString робимо QByteArray. Зауважимо, якщо у вас по тексту тільки латинські букви цілком підійде варіант з .toUtf8(). Якщо ж присутня і кирилиця - обов'язково використовуємо .toLocal8Bit(). QString strA = "Some text"; QByteArray bA = strA.toLocal8Bit().toHex(); Перетворення QByteArray в початковий текст має такий вигляд: QString strB = QString::fromLocal8Bit(QByteArray::fromHex(bA))); Цікаво, що якщо ми для зберігання записали отриманий Нех куди-небудь, наприклад, в файл або базу даних у вигляді текстового рядка, то для зворотного перетворення цей рядок потрібно додатково перетворити в QByteArray. QString strA2 = QString::fromUtf8(bA); QByteArray bB = strA2.toUtf8(); QString strB = QString::fromLocal8Bit(QByteArray::fromHex(bB)));

Qt Округлення до певного розряду

Округлення - тривіальна задача в математиці, але в Qt немає функції округлення до певного розряду. Проте в QtMath є такі функції як qFloor (qreal) і QCeil (qreal), в результаті яких int. А також можна використовуючи round (double), отримати double. Дуже швидко я знайшов ось цей ресурс звідки взяв вихідну формулу. Вона без сумніву працює, але дає результати, які не відповідаю моїм очікуванням: toRound(187.156, 2); //187.15 toRound(187.156, 1); //187.1 toRound(187.156, 0); //187 toRound(187.156, -1); //180 toRound(187.156, -2); //100 Після невеликої корекції самої функції, її підсумковий варіант виглядає так: double wcsv::toRound(double val, int r) {   double outpValue;   double tempVal;   tempVal=val*pow(10,r);   if (double(int(tempVal))+0.5==tempVal){     int(tempVal)%2 == 0       ? outpValue=double(qFloor(tempVal))/pow(10,r)       :outpValue=d...

CSV в QTableWidget

Питання виникло в зв'язку з виниклою необхідністю прочитати .xls файл в Linux'і. Я так думаю у більшості користувачів Linux, є якийсь небудь офісний пакет, такий як OpenOffice або LibreOffice або щось там ще, за допомогою якого можна легко конвертувати .xls в .сsv. А .сsv - це текст, який можна читати в будь-якій системі. Пропоную читати файл у QTableWidget. Зберемо простеньку програму. Файл file_csv.csv виглядає так:   На форму покладемо QTableWidget, QListWidget, QPushButton. void MainWindow::readFile(){     QFile file("file_csv.csv"); //файл (треба буде зробити діалог)     QStringList listA; //лист в який запишемо данні     int row = 0; //кількість рядків у майбутній таблиці (ми ж не знаємо скільки їх там ;)     if (file.open(QIODevice::ReadOnly)){         while (!file.atEnd()){             QString line = file.r...