convert table to array or matrix
3 次查看(过去 30 天)
显示 更早的评论
I have table with some extracted features like intensity, area, and diameter.these values is real values.
when I convert this table to an array, all data converted to be from 0 to 255 but I need my data in the array exactly as it in the table.....please help
1 个评论
采纳的回答
Image Analyst
2015-8-30
I assume you got those measurements from regionprops. regionprops() can now deliver its output directly in table format:
stats = regionprops(BW, 'output', 'table');
If you're using an old version of MATLAB, you can use struct2table().
3 个评论
Image Analyst
2015-8-30
Then get in a structure and concatenate into arrays with brackets. That's what I usually do
stats = regionprops(BW, grayImage, 'Area', 'EquivDiameter', 'MeanIntensity');
allAreas = [stats.Area];
allDiameters = [stats.EquivDiameter];
allIntensities = [stats.MeanIntensity];
Those will be row vectors. Of course you could concatenate into one big 2D matrix :
allMeasurements = [allAreas, allDiameters, allIntensities];
but I don't think that would help with the clarity of the program so I wouldn't recommend it. It would just make it more confusing even though there are fewer variables.
更多回答(1 个)
Peter Perkins
2015-8-31
There are two ways to converta table to a (numeric in this case) array:
1) call table2array 2) use {} subscripting for the variables you want to extract
You say, "all data converted to be from 0 to 255". Tables are all about mixed data types - one container with doubles, uints, strings, whatever in it. When you "convert to an array", what you're really doing is "converting to a single data type". So by MATLAB's precedence rules, if your table has some uint8's in it, everything (numeric) will be converted to uint8, because that's the only way you can get everything into one homogeneous array.
To get an array of doubles, you'll need to convert the non-double variables to double first.
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 Data Type Conversion 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!