access cell array inside another cell array

124 vues (au cours des 30 derniers jours)
Steffen
Steffen le 29 Oct 2014
Commenté : Walter Roberson le 3 Fév 2023
Hi,
a short question, I just can't get it running:
I have a 1x94 cell array called A with 94 600x27 cell array inside. Now, as an example, I want to access the following value: 2nd row, 3rd column, 4th cell array. How can I do that?
I want to avoid a "temporary variable" as in:
temp=A{4} value=temp(2,3)
Many thanks, Steffen
  1 commentaire
Sean de Wolski
Sean de Wolski le 29 Oct 2014
Why do you have this data structure? What is the data and what are you trying to do? There might be a more efficient way.

Connectez-vous pour commenter.

Réponse acceptée

Titus Edelhofer
Titus Edelhofer le 29 Oct 2014
Hi Steffen,
nested indexing should work:
A = cell(1,94);
A{4} = cell(600, 27);
b = A{4}{600,27}
Titus
  4 commentaires
Steffen
Steffen le 29 Oct 2014
Ah, I was blind and always tried
A{4}[600,27];
It works now! Thanks a lot!
Hina Iqbal
Hina Iqbal le 22 Mar 2015
Hi Titus Edelhofer! i also have to access the data as it is but my problem is that data in each cell array vary.. e.g;
[21x1 double]
[32x1 double]
[6x1 double]
then please tell me how to access data from this sort of data where the main cell array which contains this type of data is cell.

Connectez-vous pour commenter.

Plus de réponses (1)

N/A
N/A le 4 Mai 2017
To access 2nd row column three of 4th cell try this code
temp = A{4}(2,3)
  2 commentaires
monkeyquant
monkeyquant le 3 Fév 2023
How about this case?
>> A = {3, 9, 'a';
'B', [2,4], 0};
>> A(:, 3)
% which spits out
ans =
2×1 cell array
{'a'}
{[0]}
Now I want to access entire row or columns values from this newly extractracted cell. I tried various approach but cause Error: Invalid array indexing. A couple of examples are below:
>> A(:, 3){:, 1}
>> A(:, 3){2, 1}
Walter Roberson
Walter Roberson le 3 Fév 2023
There is no direct way to do that. You need to either use a temporary variable or a helper function
A = {3, 9, 'a';
'B', [2,4], 0};
%temporary variable
A3 = A(:,3);
A3(2,:)
ans = 1×1 cell array
{[0]}
%helper function
SelectRow = @(object, row) object(row,:);
SelectRow(A(:,3), 2)
ans = 1×1 cell array
{[0]}
The helper function only has to be created once for each context, not for every different place you want to do this kind of indexing.

Connectez-vous pour commenter.

Catégories

En savoir plus sur Cell Arrays 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