Good way for append some string to every line of exists text file
-
I need append various string to every row of text file.
Example
Before:
bq.
aaa|bbb
ccc|ddd
eee|fffAfter:
bq.
aaa|bbb|ggg
ccc|ddd|hhh
eee|fff|jjjYour suggestions?
-
I don't have any other idea than to copy the file line by line (using readLine() of a [[Doc:QTextStream]]) and append the string on the write step.
-
If the files are not too big, I would read it to a QStringList and append there. Then store it again.
Otherwise, I would use Volker's suggestion -
If your file has new line char at the end of the lines, get the whole information (readAll()) and split it using the newline char to get QStringList. From there you can split every QString with your delimiter to get the different values. Volker's suggestion looks more elegant though.
What's your intention? Are you trying to build some sort of a file like *.csv? If it's intended to be application settings, you will probably be better using QSettings with ini format instead.
-
Eus You are right it is CSV :) and sometimes I need add new column.
Not it's not for settings it's app for observe data, which write data changes to CSV format, for to be able build graph in MS Exel -
If your app is gonna output the csv on demand, you can always use some databse to save your data in a way which would be easier for you to work with. But I guess that would make it more complex then actually needed.
Well, the suggestions so far should work for you. I assume you validate the user input for "|" (so you don't get some "extra columns" in your csv :P). QStringList seems the way to go.
-
I don't want keep all data from file in memory, it's not needed
I'm worry about integrity data structure in file.
So I think I will create temp file for inserting and after insert just change temp file to persistent. -
[quote author="Vass" date="1316073685"]I don't want keep all data from file in memory, it's not needed
I'm worry about integrity data structure in file.
So I think I will create temp file for inserting and after insert just change temp file to persistent.[/quote]That's the way I would go. Maybe add some file locking, so that nobody can change the source file while you are processing it.
-
@Vaas: despite of the number of columns periodically updated, the number of rows in your file is fixed? How many records ?
-
[quote author="Alicemirror" date="1316275922"] the number of rows in your file is fixed?[/quote]
of course, not.[quote author="Volker" date="1316213165"]
That's the way I would go. Maybe add some file locking, so that nobody can change the source file while you are processing it.
[/quote]I solved it with temp file, just doing copy of current file, changes it, and rewrite original.
I'm not worry about external changes. I'm worry about integrity data structure after immediately power off, for example. -
@Vass: the solution of temp maybe good, I have adopted a similar in a application where I need to download a file and ony when the file is correctly stored on the (tmp folder) device then I can decide if the older file should be delete and substituted by the newly loaded.
Despite of this, what I mean is the following:
having a set of csv records (rows) where you periodically should add a new value (field -> excel colum) to all the records is it possible that the best approach is to inver rows and columns? It the element growing is the number of columns this will be the number of samples. Obviously it is only an intuituion because I don't know the data nature of your samples.
-
@Alicemirror Unfortunately, rows count not fixed, and changes more often than column count.
-
@Vass: you have created a monster! :)
-
:)
No, it is just parser of table from web -
Interesting ...
I have done somthing time ago and it was really helpful the solutions adopted by the wget command (Linux) -
I mean it's no general parser of tables from web :)
It's one local task on my freelance work. :) -
Yes I had understood :)
Probably there are not best ways to manage these data. Regarding the proposal of a SQLite database on the device, did you checked if this component has some kind of protection on the transictions to give you the robustness that you need against data loss ?
-
One of customer requrements: nothing databases - only CSV :)
-
Me too I'm fighting with customer in these days. They have always great ideas :) Seems very experts in mobile development...