假设我有一些.csv文件如下:
1,2,5,5,
0,5,6,9,
3,2,5,7,
1,2,3,6,
如何在每行末尾删除','符号?
P.S。
例如,我知道如何清除行尾的空间 - file.readLine().trimmed();
,但如何对其他符号执行相同操作,我不知道。
答案 0 :(得分:1)
这对我有用:
#include <QCoreApplication>
#include <QFile>
#include <QIODevice>
#include <QTextStream>
int main(int argc, char *argv[])
{
QCoreApplication a(argc, argv);
QFile inFile("input.csv");
if(!inFile.open(QIODevice::ReadOnly))
exit(1);
QString newFileData;
QTextStream in(&inFile);
//Read file line by line until it reaches the end
while(!in.atEnd())
{
QString line = in.readLine();
newFileData.append(line);
int positionOfLastChar = newFileData.length()-1;
char lastChar = newFileData.at(positionOfLastChar).toLatin1(); //Returns the character bevore the last character
if(lastChar == ',')
newFileData.remove(positionOfLastChar, //Remove at the position of the previous character
1 //one character
);
newFileData.append('\n'); //Append the newline again, because in.readLine() ignored it
}
inFile.close();
QFile outFile("output.csv");
if(!outFile.open(QIODevice::WriteOnly | QIODevice::Truncate))
exit(1);
//Write the data to the output file
QTextStream out(&outFile);
out << newFileData;
outFile.close();
return a.exec();
}
我希望这会有所帮助。
答案 1 :(得分:1)
假设您已经知道如何逐行阅读,这种原始方法可行:
QString testStr = QString("1,2,5,5,");
QStringList testList = testStr.split(",");
qDebug() << "testList" << testList;
testList.removeLast();
qDebug() << "testList" << testList;
testStr = testList.join(",");
qDebug() << "testStr" << testStr;
//输出
testList ("1", "2", "5", "5", "")
testList ("1", "2", "5", "5")
testStr "1,2,5,5"
答案 2 :(得分:0)
你也可以用另一种方式制作。您可以阅读此文line by line
和push.back() to vector
。然后你可以循环调用你的所有向量,你可以删除last items of vectors
。然后,如果你想,你可以将你的矢量写入txt文件。之后,您的','将被删除。
答案 3 :(得分:0)
这是另一种方式,不将整个文件存储在内存中。它还显示了控制台应用程序如何处理错误。
#include <QCoreApplication>
#include <QStringList>
#include <QFile>
#include <QTextStream>
#include <cstdio>
QTextStream err(stderr);
int main(int argc, char *argv[])
{
QCoreApplication a(argc, argv);
if (a.arguments().length() != 3) {
err << "Usage: " << a.arguments()[0] << " infile outfile" << endl;
return 1;
}
QFile fin(a.arguments()[1]), fout(a.arguments()[2]);
if (! fin.open(QIODevice::ReadOnly)) {
err << "Can't open input file: " << fin.fileName() << endl;
return 2;
}
if (! fout.open(QIODevice::WriteOnly)) {
err << "Can't open output file: " << fout.fileName() << endl;
return 3;
}
QTextStream in(&fin), out(&fout);
while (!in.atEnd()) {
QString line = in.readLine().trimmed();
if (line.endsWith(",")) line.truncate(line.length()-1);
out << line << "\n";
if (in.status() != QTextStream::Ok) {
err << "Error while reading." << endl;
return 4;
}
if (out.status() != QTextStream::Ok) {
err << "Error while writing." << endl;
return 5;
}
}
return 0;
}