フィルターのクリア

making multiple copies of a file

22 ビュー (過去 30 日間)
Ram
Ram 2011 年 9 月 1 日
回答済み: Sam Apoola 2019 年 2 月 14 日
I would like to make multiple copies of a file each of which will have a different name. example: source file: A.txt copies A1.txt, A2.txt... How can I use copyfile and be able to do this? Thanks for inputs

採用された回答

Walter Roberson
Walter Roberson 2011 年 9 月 1 日
copyfile() can only create one copy at a time, so you will need a loop (whether explicit or implicit)
One of numerous possible ways:
sourcefile = 'A.txt';
numcopies = 20;
[path, basename, ext] = fileparts(sourcefile);
filepattern = fullfile(path, [basename '%d.' ext]);
destnames = cellstr(num2str((1:numcopies).', filepattern);
cellfun(@(FID) copyfile(sourcefile, FID), destnames);
  4 件のコメント
Ram
Ram 2011 年 9 月 1 日
I have an error that they are too namy input arguments in the use of the function cellstr. Do you know what might be causing it.
thanks
Walter Roberson
Walter Roberson 2011 年 9 月 1 日
Looks like I left off a close bracket:
destnames = cellstr(num2str((1:numcopies).', filepattern));

サインインしてコメントする。

その他の回答 (3 件)

Amith
Amith 2012 年 12 月 26 日
will this work
copyfile('output2.txt',destnames(i));
  1 件のコメント
Walter Roberson
Walter Roberson 2012 年 12 月 26 日
No, destnames here is a cell array of strings, so destnames(i) would be a 1 x 1 cellarray, rather than a string. If you used destnames{i} then that would be a string.
You would need to loop "i" over all of the output string possibilities. The cellfun() that I show is responsible for that.

サインインしてコメントする。


Diana Krupnik
Diana Krupnik 2019 年 1 月 28 日
This solution names the files by numbering them, would it be possible to instead change the names based on a table that contains string or text?

Sam Apoola
Sam Apoola 2019 年 2 月 14 日
This worked for me
% loop for creating 100 copies
n=100;
for i=1:n
jobname{i}= ['copy', num2str(i),'.txt'];
copyfile('original.txt',jobname{i});
end

カテゴリ

Help Center および File ExchangeWorkspace Variables and MAT-Files についてさらに検索

タグ

Community Treasure Hunt

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

Start Hunting!

Translated by