Appending 2 Tables with different column order and different number of columns

조회 수: 13 (최근 30일)
Hi,
I need to append tables with different column orders but have the same header for the respecitve columns. For example
A.Properties.VariableNames={'org01','org02','org03','org04',SQ001','SQ002',SQ003'};
B. Properties.VariableNames={'org01','org03','org02',SQ002','SQ003',SQ001'};
How can I append B columns to A columns for the columns that have the same header while assigning for the variables in A that don't have equivalent in B such as org04 NaN values.

채택된 답변

Cris LaPierre
Cris LaPierre 2021년 1월 10일
편집: Cris LaPierre 2021년 1월 10일
MATLAB can use variable names in a table to concatenate two tables even if the order is different. When all the variables are in all tables, use the normal vertical concatenation technique.
It's more challenging if all tables do not have all the variables. MATLAB will fill the unassigned variable(s) with the default value for the datatype. That is 0 for doubles, not NaN (see the warning message below)
% Create 2 tables
org01=(1:5)';
org02=org01;
SQ001=org01;
T1 = table(org01,org02,SQ001)
T1 = 5x3 table
org01 org02 SQ001 _____ _____ _____ 1 1 1 2 2 2 3 3 3 4 4 4 5 5 5
% Table 2 is a subset of the variable of T1
T2 = flip(T1(:,["SQ001","org01"]))
T2 = 5x2 table
SQ001 org01 _____ _____ 5 5 4 4 3 3 2 2 1 1
% Add T2 variable values to T1
T1(end+1:end+height(T2),T2.Properties.VariableNames)=T2
Warning: The assignment added rows to the table, but did not assign values to all of the table's existing variables. Those variables are extended with rows containing default values.
T1 = 10x3 table
org01 org02 SQ001 _____ _____ _____ 1 1 1 2 2 2 3 3 3 4 4 4 5 5 5 5 0 5 4 0 4 3 0 3 2 0 2 1 0 1
If you really want them to be NaN, there are a couple options. If you want to make all 0s NaN, look into the standardizemissing function. If there will be zeros elsewhere you don't want to change to NaN, you can use a comparison of variable names along with some indexing to set just the extended variables to NaN. Here's an eample.
% Identify the new rows, and just the variables that were not in T2
T1{end-height(T2)+1:end,~ismember(T1.Properties.VariableNames,T2.Properties.VariableNames)}=NaN
T1 = 10x3 table
org01 org02 SQ001 _____ _____ _____ 1 1 1 2 2 2 3 3 3 4 4 4 5 5 5 5 NaN 5 4 NaN 4 3 NaN 3 2 NaN 2 1 NaN 1
  댓글 수: 6
Marcus Glover
Marcus Glover 2024년 2월 24일
편집: Marcus Glover 2024년 2월 24일
Just wanted to add this helped me out and add my last line to anyone looking to remove a row that does not appear in the new table
% Remove rows that were not in T2
T1(:,~ismember(T1.Properties.VariableNames,T2.Properties.VariableNames))=[]
T1 = 10x2 table
org01 SQ001 _____ _____ 1 1 2 2 3 3 4 4 5 5 5 5 4 4 3 3 2 2 1 1

댓글을 달려면 로그인하십시오.

추가 답변 (0개)

카테고리

Help CenterFile Exchange에서 Logical에 대해 자세히 알아보기

태그

Community Treasure Hunt

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

Start Hunting!

Translated by