Cell contents reference from a non-cell array object.

4 views (last 30 days)
Hi,
I am dealing with the following error:
Cell contents reference from a
non-cell array object.
The error points me to the following line:
Error using dataset/subsrefDot
(line 80)
which corresponds to:
update(conn, tablename, columnnames, data, whereclause);
Any ideas on how to deal with the error? If needed i can provide the full code as well.
  6 Comments
Adam
Adam on 16 Dec 2014
Is
l_equities.CONVERSION
a cell array?
You can just stick a breakpoint in and easily find out this kind of thing from a fairly explicit error like that.

Sign in to comment.

Accepted Answer

Sean de Wolski
Sean de Wolski on 16 Dec 2014
Apparently it's not a cell array at that point. Or something else is horribly wrong. This is where debug stop on errors is your best friend:
Run:
dbstop if error
This sets a condition to stop when an error is thrown so you can see everything as it is at the time of the error. Then recreate the error.
My magic eight ball guess is that l_equities.CONVERSION is empty; that it will eventually become a cell array but is not on your first iteration.
  4 Comments
Sean de Wolski
Sean de Wolski on 16 Dec 2014
The above is not a cell array. If it was it would look like this:
ans =
[ 3]
[50]
[30]
[ 1]
And thus the {} braces are not appropriate. You could use (), it should no longer error for the same reason, but I don't know if the results are expected.

Sign in to comment.

More Answers (2)

Image Analyst
Image Analyst on 16 Dec 2014
It's not clear that l_equities.CONVERSION is even defined at that point. I searched the entire code you provided and the first time you even mentioned l_equities.CONVERSION was when you tried to display its values. But I would think you would have gotten a different error like "Reference to non-existent field 'CONVERSION'." so it probably got defined when you assigned EQUITIES_curs.Data to l_equities - "Data" must have been a structure itself with fields like "Conversion". What happens if you put these lines
l_equities
whos(l_equities)
fieldnames(l_equities)
whos(l_equities.CONVERSION)
after this call:
%Assign data to output variable
l_equities = EQUITIES_curs.Data
and also before the disp() call. Don't use semicolons at the ends of the lines.
And finally, I think "debugging by back and forth postings in a discussion forum" is tedious and takes way way too long, so what can you learn from this link.
  1 Comment
Paul
Paul on 16 Dec 2014
thanks for all the answers. Indeed i replaced the brackets { by ( and the code works now

Sign in to comment.


Paul
Paul on 16 Dec 2014
Problem solved by replacing these brackets { by (.

Products

Community Treasure Hunt

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

Start Hunting!