文档

setdiff

设置两个数组的差值

语法

C = setdiff(A,B)
C = setdiff(A,B,'rows')
[C,ia] = setdiff(A,B)
[C,ia] = setdiff(A,B,'rows')
[C,ia] = setdiff(___setOrder)
[C,ia] = setdiff(A,B,'legacy')
[C,ia] = setdiff(A,B,'rows','legacy')

描述

例子

C= setdiff (A、B返回的数据一个这不在B,没有重复。C是有序的。

  • 如果一个而且B那么是表格还是时间表呢setdiff返回的行。一个这些都不在B.的航班时刻表,setdiff考虑行时间以确定相等性,并对输出时间表进行排序C乘以行数。

C= setdiff (A、B, '行')处理每一行一个每一行B作为单个实体,并从返回的行一个这些都不在B,没有重复。C是有序的。

“行”选项不支持单元格数组,除非其中一金宝app个输入是类别数组或日期时间数组。

例子

Cia= setdiff(A、B也返回索引向量ia

  • 一般来说,C = A(ia)

  • 如果一个而且B那么是表格还是时间表呢C = A(ia,:)

例子

Cia= setdiff(A、B, '行')也返回索引向量ia,以致于C = A(ia,:)

例子

Cia= setdiff(___setOrder返回C使用前面语法中的任何输入参数以特定顺序。setOrder可以“排序”“稳定”

  • “排序”- - - - - -C是有序的。这是默认设置。

  • “稳定”- - - - - -C和?的顺序是一样的一个

例子

Cia= setdiff(A、B“遗产”)而且Cia= setdiff(A、B、“行”、“遗产”)的行为setdiff函数来自R2012b和之前版本。

“遗产”选项不支持分类数组、日期时间数组金宝app、持续时间数组、表或时间表。

例子

全部折叠

定义两个具有共同值的向量。

A = [3 6 2 1 5 1 1];B = [2 4 6];

找到中的值一个这些都不在B

C = setdiff(A,B)
C =1 3 5

定义两个具有共同行的表。

A = table([1:5]',[“一个”“B”“C”' D '“E”),逻辑([0,1,0,1,0]))
一个=5×3表Var1 Var2 Var3 ____ ____ _____ 1 A假2 B真3 C假4 D真5 E假
B = table([1:2:10]',[“一个”“C”“E”‘G’“我”),逻辑(0(5、1)))
B =5×3表Var1 Var2 Var3 ____ ____ _____ 1 A假3 C假5 E假7 G假9 I假

中的行一个这些都不在B

C = setdiff(A,B)
C =2×3表Var1 Var2 Var3 ____ ____ _____ 2 B真4 D真

定义两个具有共同值的向量。

A = [3 6 2 1 5 1 1];B = [2 4 6];

找到中的值一个这些都不在B还有索引向量ia,以致于C = A(ia)

[C,ia] = setdiff(A,B)
C =1 3 5
ia =4 1 5

定义一个表,一个五个人的性别、年龄和身高。

A =表([“米”“米”“F”“米”“F”]、[27;52;31;46;35],[74;68;64;61;64),...“VariableNames”, {“性别”“年龄”“高度”},...“RowNames”, {“泰德”“弗雷德”“贝蒂”“鲍勃”“朱迪”})
一个=5×3表性别年龄身高______ ___ ______泰德M 27 74弗雷德M 52 68贝蒂F 31 64鲍勃M 46 61朱迪F 35 64

定义一个表,B,用相同的变量一个

B = table([“F”“米”“F”“F”],[64; 68; 62; 58],[31, 47岁,35岁,23],...“VariableNames”, {“性别”“高度”“年龄”},...“RowNames”, {梅格的“乔”“贝丝”“艾米”})
B =4×3表性别身高年龄______ ______ ___梅格F 64 31乔M 68 47贝丝F 62 35艾米F 58 23

中的行一个这些都不在B,以及索引向量ia,以致于C = A(ia,:)

[C,ia] = setdiff(A,B)
C =4×3表性别年龄身高______ ___ ______朱迪F 35 64特德M 27 74鲍勃M 46 61弗雷德M 52 68
ia =5 1 4 2

一排排的C是按顺序排列的吗性别接下来是年龄

定义两个具有共同行的矩阵。

A = [7 9 7;0 0 0;7 9 7;5 5 5;1 4 5];B = [0 0 0;5 5 5];

找到的行一个这些都不在B还有索引向量ia,以致于C = A(ia,:)

[C,ia] = setdiff(A,B,)“行”
C =1 4 5 7 9 7
ia =5个1

使用setOrder参数指定中的值的顺序C

指定“稳定”“排序”当值的顺序C是很重要的。

A = [3 6 2 1 5 1 1];B = [2 4 6];[C,ia] = setdiff(A,B,)“稳定”
C =3 1 5
ia =1 4 5

或者,您也可以指定“排序”秩序。

[C,ia] = setdiff(A,B,)“排序”
C =1 3 5
ia =4 1 5

定义两个向量

A =[5楠楠];B = [5 NaN];

的集合差一个而且B

C = setdiff(A,B)
C =南南

setdiff对待不同的价值。

创建一个字符向量的单元格数组,一个

A = {“狗”“猫”“鱼”“马”};

创建一个字符向量的单元格数组,B,其中一些向量有尾随空白。

B = {“狗”“猫”“鱼”“马”};

找到其中的字符向量一个这些都不在B

[C,ia] = setdiff(A,B)
C =1×2单元格数组“狗”的“鱼”
ia =1 3

setdiff将字符向量的单元格数组中的尾随空白处理为不同的字符。

创建一个字符向量,一个

A = [“猫”“狗”“狐狸”“猪”];类(一)
Ans = 'char'

创建一个字符向量的单元格数组,B

B = {“狗”“猫”“鱼”“马”};类(B)
Ans = 'cell'

找到其中的字符向量一个这些都不在B

C = setdiff(A,B)
C =2×1单元格数组“福克斯”“猪”

结果,C,是字符向量的单元格数组。

类(C)
Ans = 'cell'

使用“遗产”标志来保存的行为setdiff从R2012b和之前版本的代码。

求的差值一个而且B与当前的行为。

A = [3 6 2 1 5 1 1];B = [2 4 6];[C1,ia1] = setdiff(A,B)
C1 =1 3 5
ia1 =4 1 5

求的差值一个而且B,并保留遗留行为。

[C2,ia2] = setdiff(A,B,)“遗产”
C2 =1 3 5
ia2 =7 1 5

输入参数

全部折叠

输入数组,指定为数值数组、逻辑数组、字符数组、字符串数组、类别数组、日期时间数组、持续时间数组、字符向量、表格或时间表的单元格数组。如果指定“行”选项,一个而且B列数必须相同。

一个而且B必须属于同一个类,但有以下几种例外:

  • 逻辑字符,并且所有的数值类都可以与数组。

  • 字符向量的单元格数组可以与字符数组或字符串数组组合。

  • 分类数组可以与字符数组、字符向量的单元格数组或字符串数组组合。

  • 日期时间数组可以与日期字符向量的单元格数组或单个日期字符向量组合。

还有额外的要求一个而且B根据数据类型:

  • 如果一个而且B都是序数范畴数组,它们必须具有相同的类别集,包括它们的顺序。如果既不一个也不B是序数的,它们不需要具有相同的类别集,并且使用类别名称执行比较。在本例中,类别C是分类的排序并集吗一个而且B

  • 如果一个而且B无论是表还是时间表,它们必须具有相同的变量名(除了顺序)。对于表,行名被忽略,因此具有相同值但名称不同的两行被认为是相等的。对于时间表,要考虑行时间,因此具有相同值但时间不同的两行不被认为相等。

  • 如果一个而且B作为datetime数组,它们必须在是否指定时区方面彼此一致。

一个而且B也可以是具有以下类方法的对象:

  • 排序(或sortrows“行”选项)

  • 情商

对象类方法必须彼此一致。这些对象包括派生自同一根类的异构数组。例如,一个而且B可以是图形对象句柄的数组。

命令标志,指定为“排序”“稳定”中的值(或行)的顺序C

订单的旗帜 意义
“排序” 中的值(或行)C按排序顺序返回。例如:C = setdiff([4 1 3 2],[2 1],'sorted')返回C = [3 4]
“稳定” 中的值(或行)C按与中相同的顺序返回一个.例如:C = setdiff([4 1 3 2],[2 1],'stable')返回C = [4 3]

输出参数

全部折叠

的差异一个而且B,作为向量、矩阵、表或时间表返回。如果输入一个而且B表或时间表,那么变量的顺序C和变量的顺序一样吗一个

下面描述的形状C当输入是向量或矩阵时,当“遗产”标志未指定:

  • 如果“行”标志未指定且一个是行向量吗C是行向量。

  • 如果“行”标志未指定且一个不是行向量吗C是列向量。

  • 如果“行”则指定FlagC矩阵是否包含的行一个这些都不在B

  • 的所有值(或行)一个也在B,然后C是一个空矩阵。

的班级C是和班级一样的吗一个,除非:

  • 一个字符数组和B是字符向量的单元格数组,在哪种情况下C是字符向量的单元格数组。

  • 一个是字符向量、字符向量的单元格数组或字符串,还是B是直言数组,在哪种情况下C是一个类别数组。

  • 一个单元格数组是字符向量还是单个字符向量和B是datetime数组,在哪种情况下C是一个日期时间数组。

  • 一个是字符向量或字符向量的单元格数组和B是字符串数组,在哪种情况下C是一个字符串数组。

索引一个时作为列向量返回“遗产”Flag未指定。ia中的值(或行)一个这些都不在B.中出现重复的值(或行)一个,然后ia包含值(或行)第一次出现的索引。

提示

  • 要查找表或时间表中变量子集的集合差异,可以使用列下标。例如,你可以用setdiff ((:,var), B (:,var)),在那里var是正整数、正整数的向量、变量名、变量名的单元格数组或逻辑向量。或者,您也可以使用vartype创建选择指定类型的变量的下标。

扩展功能

R2006a之前介绍过

这个话题有帮助吗?