How do I convert a value from a cell array into an integer?
27 Ansichten (letzte 30 Tage)
Ältere Kommentare anzeigen
Eggo Ogge
am 2 Mär. 2011
Kommentiert: Prateek Nagvani
am 20 Mai 2019
My problem is when I read one cell from table, for example 5, I need to convert this in integer value.
I try cell2mat function, but this function converts in matrix form and when I want to multiply it, it gets matrix but I only need a scaler:
d=5 (from the table)
e=cell2mat(d)
f=e*1 there i don't get 5, I get 53.
That is a problem for me.
1 Kommentar
David Young
am 2 Mär. 2011
Please could you show a few lines of code that illustrate the problem? It should be possible to cut and paste the code from your question into MATLAB and replicate the result.
Akzeptierte Antwort
Matt Tearle
am 2 Mär. 2011
In addition to what David and Andreas said, I'm wondering if this table is coming from a GUI (ie a uitable) or something like that, so you're actually getting a string representation. In fact, if "5"*1 is resulting in 53, I'd bet that's the problem. Take a look in your Workspace at the class of d or type whos d in the Command Window. The solution is simple: use str2num to convert the table of strings to numbers.
As an aside, you don't need cell2mat for a single element of the table, just index in with curly braces, rather than parentheses. c(4,2) will return a single cell containing the string '5'; c{4,2} will return the contents of that cell - the string itself.
4 Kommentare
Ahmed Abdellatif
am 26 Feb. 2018
Finding this answer after 1 day of searching was very helpful, thank you
Weitere Antworten (1)
Andreas Goser
am 2 Mär. 2011
In MATLAB, also a scalar is a matrix - a 1x1 matrix.
In MATLAB the default data type is DOUBLE - so even if you assign
d=5;
the internal representation will not be exact 5. But you can work with integers data types see e.g. UINT16.
0 Kommentare
Siehe auch
Kategorien
Mehr zu Data Type Conversion finden Sie in Help Center und File Exchange
Produkte
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!