可変引数を取る関数があります。これらの引数はパラメーターと値のペアでvarargin
あり、奇数インデックスの要素がすべて文字列 (パラメーター) であるセル配列も同様ですが、偶数インデックスの要素は文字列、数値、または文字列のセル配列にすることができます。で特定の文字列のインデックスを検索したいvarargin
。有効なソリューションがありますが、arrayfun
2 回使用します。そのようなセル配列で文字列を見つけるための、よりクリーン/高速/より効果的な方法はありますか? 結果index
は、その要素と次の要素を から削除するために使用されvarargin
ます。新しい変数の作成を最小限に抑えたいと思います。
str_to_find = 'paramX'
finds = arrayfun(@(i) strfind(varargin{i},str_to_find), 1:length(varargin), 'UniformOutput', 0);
finds2 = arrayfun(@(i) ~iscell(finds{i}) && ~isempty(finds{i}), 1:length(finds));
index = find(finds2==1);
varargin(index)=[];
varargin(index)=[];
与えられたvarargin
is {'paramA', 'valueA', 'paramB', 9, 'paramX', {'z','x','c'}
、次にfinds
is [] [] [] [] [1] {1x3 cell}
、finds2
is 0 0 0 0 1 0
、およびindex
is5
です。したがって、私のソリューションは必要なことを行いますが、見苦しく見えます。その要素を から削除するfinds2
には (つまり、 create ではなく)使用するだけですが、その後の要素も削除する必要があります。index
varargin