Selecting particular data range from table/ columns
39 visualizaciones (últimos 30 días)
Mostrar comentarios más antiguos
Tyson Campbell
el 18 de Abr. de 2020
Comentada: Star Strider
el 20 de Abr. de 2020
Hi there,
I am very new to Matlab and haven't been able to find the following solution.
I have two columns within a table of 1537090 x 2. Within the second column I want to extract numbers that fall within a range of 15 to 50.
Any numbers that are found in that range in column 2 I would like the corresponding row from Column 1 to also be pulled out.
The result will be another two column table but have all values within 15 to 50 from Column 2 and the corresponding rows from Column 1.
Thanks very much in advance and really appreciate any help.
0 comentarios
Respuesta aceptada
Star Strider
el 18 de Abr. de 2020
Try this:
T1 = table(rand(100,1), randi(75,100,1)); % Original Table
L = table2array(varfun(@(x)((x>=15) & (x<=50)), T1(:,2))); % Logical Vector
T2 = T1(L,:); % Edited Table
.
10 comentarios
Más respuestas (1)
Sindar
el 18 de Abr. de 2020
Editada: Sindar
el 18 de Abr. de 2020
idx = (mytable{:,2} >= 15) & (mytable{:,2} <= 50);
newtable = mytable(idx,1:2);
Components of the answer:
- extract the data in the 2nd column (note {}; () would return a table)
mytable{:,2}
- identify which elements of this array (i.e. which rows of the table) are >= 15. This returns a logical array (true where >=15, false elsewhere)
(mytable{:,2} >= 15)
- elementwise AND with the other condition (<=50) so true only in the range
() & ()
- extract the appropriate rows from the table (and columns, though ":" would work as well if you want all the columns)
mytable(idx,1:2)
0 comentarios
Ver también
Categorías
Más información sobre Structures en Help Center y File Exchange.
Productos
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!