Add new variable to table based on condition
Mostrar comentarios más antiguos
Hi,
I apologize for the newbie question but how does one add a variable to a table in Matlab based on conditions applied to other variables ?
For example, in the code below if t.y < 4 & t.y > 2 then 'A' should be stored in a new collumn t.z. Which doesnt work. Any ideas ?
y = [1 2 3 4];
x = [5 6 7 8];
t = table(x', y', 'VariableNames', {'x', 'y'})
if t.y < 4 & t.y > 2
t.z = 'A'
end
5 comentarios
Bob Thompson
el 26 de Jun. de 2019
You won't have success doing this for one thing because you're looking to add a single element to a table which has four rows. Matlab doesn't like introducing a new column with one element when there are more than one rows in an array of any kind. Try adding the t.z column first and then setting the value to 'A.'
Adam Danz
el 26 de Jun. de 2019
Also, the logical tests below will be true only if all rows of t.y and t.x satisfy the conditions. If that's really what you're testing, you should use all().
if t.y < 4 & t.y > 2
if all(t.y < 4) & all(t.y > 2)
Walter Roberson
el 26 de Jun. de 2019
More likely,
mask = t.y > 2 & t.y < 4;
t.z(mask) = 'A';
Bob Thompson
el 27 de Jun. de 2019
Would using a logic index range for an undefined variable work though? I would think that if t.z didn't exist already then you would still run into the same issue Blue has. I get that the range covers a set of elements the same size as the other variables, but what values are entered for mask == 0? Do they just get created as empty? Is that allowed in a table?
Adam Danz
el 27 de Jun. de 2019
Yes, mask=0 elements are merely empty strings ('')
y = [1 2 3 4];
x = [5 6 7 8];
t = table(x', y', 'VariableNames', {'x', 'y'})
mask = t.y > 2 & t.y < 4;
t.z(mask) = 'A';
t =
4×3 table
x y z
_ _ _
5 1
6 2
7 3 A
8 4
Respuestas (0)
Categorías
Más información sobre Tables en Centro de ayuda y File Exchange.
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!