Splitting a table to 2

3 visualizaciones (últimos 30 días)
Rafi Kandli
Rafi Kandli el 16 de Ag. de 2017
Comentada: KL el 16 de Ag. de 2017
Hello all, I have a table named A. I want to split it into 2 sub-tables: Table 1 has 60% of the rows in A, chosen randomly. Table 2 has all the other rows that are not in table 1. Any elegant idea on how to do this?

Respuesta aceptada

KL
KL el 16 de Ag. de 2017
dummy = 10*rand(10,4);
T = array2table(dummy)
ranRows = randperm(length(dummy));
T1 = T(ranRows(1:(0.6*length(dummy))),:)
T2 = T(ranRows((0.6*length(dummy))+1:end),:)
  2 comentarios
Guillaume
Guillaume el 16 de Ag. de 2017
The proper function for getting the height of a table is height, so:
ranrows = randperm(height(T));
T1 = T(ranRows(1:0.6*height(T)), :);
T2 = T(ranRows(0.6*height(T)+1:end), :);
To avoid a warning, I would also wrap the 0.6*height(T) calculation inside a ceil, a floor or a round.
KL
KL el 16 de Ag. de 2017
Thanks Guillaume!

Iniciar sesión para comentar.

Más respuestas (2)

Adrian
Adrian el 16 de Ag. de 2017
Editada: Adrian el 16 de Ag. de 2017
Note that this will only play nicely if you have a reasonably large array.
selection = randi([1 10], size(A,1),1)
A_sixty = A(selection>4);
A_forty = A(selection<=4);

Sean de Wolski
Sean de Wolski el 16 de Ag. de 2017
If you're looking to split your data into a training and testing set, then it might pay to look at cvpartition as well, it provides more options for splitting tables.

Categorías

Más información sobre Tables en Help Center y File Exchange.

Etiquetas

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by