ASCII File Import
An example showing how to import data from an ASCII file into a Spreadsheet.
#include <iostream>
#include <QApplication>
#include "labplot.h"
int main(int argc, char* argv[]) {
QApplication app(argc, argv);
AsciiFilter filter;
auto p = filter.properties();
p.automaticSeparatorDetection = true;
p.separator = QStringLiteral(";");
p.headerEnabled = true;
p.headerLine = 1;
p.commentCharacter = QStringLiteral("#");
p.intAsDouble = false;
p.removeQuotes = true;
p.dateTimeFormat = QStringLiteral("MM/dd/yyyy");
filter.setProperties(p);
Spreadsheet spreadsheet(QStringLiteral("test"), false);
filter.readDataFromFile(QStringLiteral("data.txt"), &spreadsheet, AbstractFileFilter::ImportMode::Replace);
if (!filter.lastError().isEmpty()) {
std::cout << "Import error: " << filter.lastError().toStdString() << std::endl;
return -1;
}
std::cout << "Number of columns: " << spreadsheet.columnCount() << std::endl;
std::cout << "Number of rows: " << spreadsheet.rowCount() << std::endl;
spreadsheet.column(0)->setColumnMode(AbstractColumn::ColumnMode::Text);
spreadsheet.column(1)->setColumnMode(AbstractColumn::ColumnMode::Integer);
spreadsheet.column(2)->setColumnMode(AbstractColumn::ColumnMode::Double);
spreadsheet.column(3)->setColumnMode(AbstractColumn::ColumnMode::Day);
std::cout << "First Name: " << spreadsheet.column(0)->textAt(1).toStdString() << std::endl;
std::cout << "Age: " << spreadsheet.column(1)->integerAt(1) << std::endl;
std::cout << "Height: " << spreadsheet.column(2)->doubleAt(1) << std::endl;
std::cout << "Date of Birth: " << spreadsheet.column(3)->dateAt(1).toString().toStdString() << std::endl;
}
from pylabplot import *
filter = AsciiFilter()
p = filter.properties()
p.automaticSeparatorDetection = True
p.separator = ";"
p.headerEnabled = True
p.headerLine = 1
p.commentCharacter = "#"
p.intAsDouble = False
p.removeQuotes = True
p.dateTimeFormat = "MM/dd/yyyy"
filter.setProperties(p)
spreadsheet = Spreadsheet("test", False)
filter.readDataFromFile("data.txt", spreadsheet, AbstractFileFilter.ImportMode.Replace)
if filter.lastError():
print(f"Import error: {filter.lastError()}")
exit(1)
print(f"Number of columns: {spreadsheet.columnCount()}")
print(f"Number of rows: {spreadsheet.rowCount()}")
spreadsheet.column(0).setColumnMode(AbstractColumn.ColumnMode.Text)
spreadsheet.column(1).setColumnMode(AbstractColumn.ColumnMode.Integer)
spreadsheet.column(2).setColumnMode(AbstractColumn.ColumnMode.Double)
spreadsheet.column(3).setColumnMode(AbstractColumn.ColumnMode.Day)
print(f"First Name: {spreadsheet.column(0).textAt(1)}")
print(f"Age: {spreadsheet.column(1).integerAt(1)}")
print(f"Height: {spreadsheet.column(2).doubleAt(1)}")
print(f"Date of Birth: {spreadsheet.column(3).dateAt(1)}")