Effacer les filtres
Effacer les filtres

repeat rows and export to txt file

2 vues (au cours des 30 derniers jours)
Jacob Weiss
Jacob Weiss le 8 Juil 2021
Commenté : Jacob Weiss le 9 Juil 2021
I read in a txt file containing n colums and n rows. I need to repeat each row x number of times and then export the new file to a txt document. I.E
A=importdata('file.txt')
A = [1;2;3;4]
x= 3
A = [1;1;1;2;2;2;3;3;3;4;4;4]
exportdata('NewFile.txt')
  4 commentaires
Mohsin Zubair
Mohsin Zubair le 8 Juil 2021
@Jacob Weiss I told you that how can you create your desired output but to export it, there are many ways to do so, it depends how or in whih format you want to export your data, also can you share your orignal text file with data?
Mohsin Zubair
Mohsin Zubair le 8 Juil 2021
well what I told is just using loops which isn't good for long file, what scott told you is much better for file of your size

Connectez-vous pour commenter.

Réponses (1)

Scott MacKenzie
Scott MacKenzie le 8 Juil 2021
Modifié(e) : Scott MacKenzie le 8 Juil 2021
I think this is more or less what you're after:
% test data (read from file)
A = [1 8;2 7;3 6;4 5]
A = 4×2
1 8 2 7 3 6 4 5
x = 3; % number of times to repeat each row (change as desired)
A1 = repmat(A', x, 1);
A2 = reshape(A1, size(A,2), [])'
A2 = 12×2
1 8 1 8 1 8 2 7 2 7 2 7 3 6 3 6 3 6 4 5
% write to file
  9 commentaires
Scott MacKenzie
Scott MacKenzie le 9 Juil 2021
@Rik. Thanks. Yes indeed, much simpler. @Jacob Weiss with Rik's simplification, something like this will also work...
f = 'https://www.mathworks.com/matlabcentral/answers/uploaded_files/678488/Raj_AZ31_16120.txt';
A = readmatrix(f);
x = 3; % number of times to repeat each row (change as desired)
B = repelem(A, x, 1);
writematrix(B,'newfile.txt');
Jacob Weiss
Jacob Weiss le 9 Juil 2021
Great thank you for all the help! I have it working now.

Connectez-vous pour commenter.

Community Treasure Hunt

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

Start Hunting!

Translated by