linux下qt对csv文件读取,从qt中的.txt或.csv文件读取一行(Qt Quick)

本文档展示了如何在C++中创建一个名为FileIO的自定义QML类型,用于执行文件的读取和写入操作。FileIO类包含一个source属性和相关的方法,如read()和write(),并提供了错误处理信号。通过在QML中注册该类型,可以在QML界面中直接使用FileIO进行文件操作,如示例所示。
摘要由CSDN通过智能技术生成

摘要:

创建自定义QML类型,FileIO专注:

fileio.h

#ifndef FILEIO_H

#define FILEIO_H

#include

class FileIO : public QObject

{

Q_OBJECT

public:

Q_PROPERTY(QString source

READ source

WRITE setSource

NOTIFY sourceChanged)

explicit FileIO(QObject *parent = 0);

Q_INVOKABLE QString read();

Q_INVOKABLE bool write(const QString& data);

QString source() { return mSource; };

public slots:

void setSource(const QString& source) { mSource = source; };

signals:

void sourceChanged(const QString& source);

void error(const QString& msg);

private:

QString mSource;

};

#endif // FILEIO_H

fileio.cpp

#include "fileio.h"

#include

#include

FileIO::FileIO(QObject *parent) :

QObject(parent)

{

}

QString FileIO::read()

{

if (mSource.isEmpty()){

emit error("source is empty");

return QString();

}

QFile file(mSource);

QString fileContent;

if (file.open(QIODevice::ReadOnly)) {

QString line;

QTextStream t(&file);

do {

line = t.readLine();

fileContent += line;

} while (!line.isNull());

file.close();

} else {

emit error("Unable to open the file");

return QString();

}

return fileContent;

}

bool FileIO::write(const QString& data)

{

if (mSource.isEmpty())

return false;

QFile file(mSource);

if (!file.open(QFile::WriteOnly | QFile::Truncate))

return false;

QTextStream out(&file);

out << data;

file.close();

return true;

}

注册新的QML类型:

#include "fileio.h"

Q_DECL_EXPORT int main(int argc, char *argv[])

{

...

qmlRegisterType("FileIO", 1, 0, "FileIO");

...

}

实际QML用法:

import QtQuick 1.1

import FileIO 1.0

Rectangle {

width: 360

height: 360

Text {

id: myText

text: "Hello World"

anchors.centerIn: parent

}

FileIO {

id: myFile

source: "my_file.txt"

onError: console.log(msg)

}

Component.onCompleted: {

console.log("WRITE"+ myFile.write("TEST"));

myText.text = myFile.read();

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值