Comparing two tables and copy elements of table 2 into table 1
이전 댓글 표시
Hi,I have two tables as given below.
Table 1:

Table 2

If column1 in table 2 is equal to column 1 in table1 T & W values in table 2 has to copy in table 1, Similar strings has to follow one after the other. If the stings are unequal T & W must be empty. I want the output as below table;

채택된 답변
추가 답변 (2개)
Peter Perkins
2019년 3월 20일
This is just an outer join:
>> T1 = table(["hello";"new";"world";"hi";"hello";"hi"],[1;2;3;5;8;7],'VariableNames',["Word" "V"])
T1 =
6×2 table
Word V
_______ _
"hello" 1
"new" 2
"world" 3
"hi" 5
"hello" 8
"hi" 7
>> T2 = table(["hi";"hello"],[2;4],[6;7],'VariableNames',["Word" "T" "W"])
T2 =
2×3 table
Word T W
_______ _ _
"hi" 2 6
"hello" 4 7
>> outerjoin(T1,T2,'MergeKeys',true)
ans =
6×4 table
Word V T W
_______ _ ___ ___
"hello" 1 4 7
"hello" 8 4 7
"hi" 5 2 6
"hi" 7 2 6
"new" 2 NaN NaN
"world" 3 NaN NaN
댓글 수: 1
Do'h! I did try using an outerjoin but using only Word as the key hence got duplicate V, T and W in the result, which I couldn't merge. Of course, If you use all columns as keys, then you get the correct outerjoin.
Note that since the data is stored in a database you don't need matlab to do the join. In SQL it'd be something like:
SELECT * FROM table1 FULL OUTERJOIN table2 ON table.Word = table2.Word
카테고리
도움말 센터 및 File Exchange에서 Tables에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!