Info

この質問は閉じられています。 編集または回答するには再度開いてください。

search and retrieve data from cell array

1 回表示 (過去 30 日間)
OpenSearch
OpenSearch 2018 年 8 月 29 日
閉鎖済み: MATLAB Answer Bot 2021 年 8 月 20 日
I have got a cell array containing a column of 1000 (thousand) 2x2 doubles.
Could someone advise on the most efficient way to search for certain numbers in those doubles? And if found (within an error range), to save them in a separate table?
Many thanks in advance!
  1 件のコメント
Stephen23
Stephen23 2018 年 8 月 30 日
編集済み: Stephen23 2018 年 8 月 30 日
"Could someone advise on the most efficient way to search for certain numbers in those doubles"
The most efficient way would probably be to use a loop. The easiest way might be to use cellfun. Probably the best way would be to have stored your data in one ND array, then you could write better, simpler, vectorized code:

回答 (1 件)

Matthew
Matthew 2018 年 8 月 30 日
編集済み: Matthew 2018 年 8 月 30 日
The easiest way I know of is to use cellfun. For instance if you were looking for numbers that are greater than 2
arraysWithNumbersGreaterThan2_IX = cellfun(@(x) any(any(x > 2)), inputArray)
seperateList = inputArray(arraysWithNumbersGreaterThan2_IX);
If you want to find arrays that have 1, 4, or 7 in them
arraysWithCertainNumbers_IX = cellfun(@(x) any(ismember([1,4,7],x)), inputArray)
seperateList = inputArray(arraysWithCertainNumbers_IX);

Community Treasure Hunt

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

Start Hunting!

Translated by