How do I convert table data to double to manipulate them?
Show older comments
I extract data from a table. When I retrieve an element, it is in table format, but I encounter an error when attempting to perform operations like multiplication. Is there a direct command or a series of steps to address this issue?
3 Comments
Jan
on 2 Dec 2017
Please post any details: An example input, the code you use and the complete error message. Then writing an answer requires less guessing, what you are doing.
"I extracted data from a table, when I get an element it comes as table format but when trying to make some operations like multiplication there is an error, is there any direct command or a series of steps?"
You could use TABLE2ARRAY, but by far the simplest and most efficient approach is to just use the correct indexing using curly braces to access the table content (not parentheses which returns another table, which is what you did).
The different types of indexing are clearly explained in the documentation:
Peter Perkins
on 8 Nov 2021
This new example goes even further into indexing and the topic of "doing math on data stored in a MATLAB table":
It's a new-for-R2021b example, but doesn't require the latest MATLAB for anything (most anything?) it covers.
Accepted Answer
More Answers (3)
Peter Perkins
on 19 Dec 2017
0 votes
The answer might be as simple as something like T.Z = T.x .* T.y. Without more information, hard to tell.
Roger Breton
on 8 Mar 2021
Edited: Roger Breton
on 8 Mar 2021
0 votes
It does not work for me : all I want is to be able to import a range from Excel, and all I get is a "Table" on which I can't do any operation?
3 Comments
Peter Perkins
on 9 Mar 2021
Tables are containers for mixed-type data, which is why they don't support "math". You haven't said anything about what you have in the spreadsheet or what you want to do with it. Maybe all your data are all numeric. The syntax I suggested might be what you are looking for to do your operation, or maybe you want to use table2array as SS suggested. Hard to say with no information.
Roger Breton
on 9 Mar 2021
Thank you so much for extending your kind help, Peter.
Yes, all my data is numieric, doubles, in fact. It's just that I'm totally "green" with regards to MatLab data types. I think I used the table2array function to "convert" the data. Once converted, I was able to carry my "normal" arithmetic operation. I really have to give myself the time to learn Matlab...
Arshey Dhangekar
on 7 Jul 2021
0 votes
Hello I have csv data of 18 columns and want to convert into double
so instead of writing 18 str2double code how can I convert all the 18 columns in short line of code
Temp.x310_Ambient__C_ = str2double (Temp.x310_Ambient__C_);
3 Comments
Peter Perkins
on 27 Jul 2021
1) Post a new question, don't ask a question in a reply to someone else's question.
2) Try varfun or convertvars.
3) Get to the root cause and figure out why your numeric spreadsheet is being read in as text.
Mohsin Munir
on 25 Aug 2021
I have data in excel. there are some coulmns having inputs. I want if i multiply two columns in matlab then the next column to be added in the same sheet rather than a new file in workspace. can anybody help me in this problem
Peter Perkins
on 8 Nov 2021
1) Post a new question, don't ask a question in a reply to someone else's question.
2) This example may be of help for the topic of "doing math on data stored in a MATLAB table":
It's a new-for-R2021b example, but doesn't require the latest MATLAB for anything (most anything?) it covers.
Categories
Find more on Spreadsheets in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!