I want to add a column of numbers to a text file which already exists, how?

4 vues (au cours des 30 derniers jours)
Nesha Wright
Nesha Wright le 11 Juil 2018
Commenté : Adam Danz le 11 Juil 2018
I have a file with columns headers years, emissions and I want to add 'land'. The years run from 1750-2014. For the years 1959-2014 I want to add to this 'land column' a set of values. How do I do this without ruining or having to recreate the rest of the file?
  3 commentaires
Nesha Wright
Nesha Wright le 11 Juil 2018
The text file is .txt
Adam Danz
Adam Danz le 11 Juil 2018
Here are responses to the same question. If there are any follow up questions I'd be glad to chip in.

Connectez-vous pour commenter.

Réponse acceptée

dpb
dpb le 11 Juil 2018
Short answer is to just create the file anew...
t=readtable('yourfile'); % or whatever way to read; readtable is pretty flexible
land=nan(height(t,1)); % allocate for the new data column
ix=(t.years==1750); % find where to put data in array
land(ix:end)=NEWLANDDATA; % store the new values from wherever they come
t=[t land]; % augment the table
Save the file in whatever form you wish.
While it seems superficially to be better to only write new data, the effort to do so with sequential files is much more than simply reading the existing file, doing whatever machinations needed to the data in memory and then rewriting the file. While the other is possible for everything except truly humongous files it's not worth the effort.

Plus de réponses (0)

Catégories

En savoir plus sur Standard File Formats dans Help Center et File Exchange

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by