はい、読みました:Excel: 行列式 - 行列 (ベクトル) が返されないのはなぜですか?しかし、これは同じではありません。
基本的に、なぜこのような式になるのか理解できません。{=MATCH({1,2,3},{1,2,3},0)}
通常は行列 (ベクトル) を返しますが、{1,2,3}
単一の値を返します。
次の例を考えてみましょう。
注: 非常に長い導入部があります。興味深い部分は太字のテキストの下から始まります:「これまでのところ、すべてが期待どおりに動作しています。」
Name
およびリビジョンを含む表がありますcolumns
。
- それぞれの一意の名前に対して 1 つの一意の整数を持たせたいです
GroupNo
。 - 次に、修正値に応じて
GroupNo
小数点部分を加算します( )RevPart
""=0, "a"=0.01, ...
GroupNo+RevPart
FullGroupNo
は(FGN
)と呼ばれますFGN
各名前グループの最大値を知りたいです:MaxInGroup
(MIG
)
これは、テーブル内の複数の列を使用して簡単に実行できます ( Table1
)。
GroupNo: =MATCH([@Name],[Name],0)
RevPart: =INDEX({0,1},MATCH([@Revision],{"","a"},0))/100
FullGroupNo: =[@GroupNo]+[@RevPart]
MaxInGroup: {=MAX(([@GroupNo]=[GroupNo])*[FullGroupNo])}
Table1
+------+----------+---------+---------+-------------+------------+
| Name | Revision | GroupNo | RevPart | FullGroupNo | MaxInGroup |
+------+----------+---------+---------+-------------+------------+
| A | ="" | 1 | 0 | 1 | 1,01 |
| A | a | 1 | 0,01 | 1,01 | 1,01 |
| B | ="" | 3 | 0 | 3 | 3 |
| C | ="" | 4 | 0 | 4 | 4,01 |
| C | a | 4 | 0,01 | 4,01 | 4,01 |
+------+----------+---------+---------+-------------+------------+
Note: ="" means there is a blank string in the cell (formula ="")
FullGroupNo
( )は、列と列FGN
のみを参照する 1 つの数式で取得できます。Name
Revision
FGN_2: {=(INDEX({0,1},MATCH([@Revision],{"","a"},0))/100+MATCH([@Name],[Name],0))}
FGN_2 is a new column in the table (Table1) above. It's matrix formula returns single (not-matrix) value.
Area under FGN (Matrix) is an ordinary worksheet range. This whole area contains return (matrix) value.
FGN (Matrix): {=INDEX({0,1},MATCH(Table1[Revision],"","a"},0))/100+MATCH(Table1[Name],Table1[Name],0))}
Table1 Just range
+-------+ +--------------+
| FGN_2 | | FGN (Matrix) |
+-------+ +--------------+
| 1 | | 1 |
| 1,01 | | 1,01 |
| 3 | | 3 |
| 4 | | 4 |
| 4,01 | | 4,01 |
+-------+ +--------------+
MaxInGroup
ここで、単一の行列式に統合しようとしました。
Original MaxInGroup formula:
MaxInGroup: {=MAX(([@GroupNo]=[GroupNo])*[FullGroupNo])}
Step1
- replace[@GroupNo] with matrix formula with reference only to Name and Revision columns
MIG_1: {=MAX((MATCH([@Name],[Name],0)=[GroupNo])*[FullGroupNo])}
Step2
- Replace (matrix) [GroupNo] with matrix formula with reference to Name and revision columns
MIG_2: {=MAX((MATCH([@Name],[Name],0)=MATCH([Name],[Name],0))*[FullGroupNo])}
これまでのところ、すべてが期待どおりに動作しています。
Step3
- Replace (matrix) [FullGroupNo] in MIG_2 with matrix formula with reference to Name and Revidion columns
(so, basicaly I need formula from FGN (Matrix) used before
MIG_3: {=MAX((MATCH([@Name],[Name],0)=MATCH([Name],[Name],0))*(INDEX({0,1},MATCH([Revision],{"","a"},0))/100+MATCH([Name],[Name],0)))}
Note: MIG_3 is part of the Table1 so column names only are enough
So now we could have same values in MaxInGroup, MIG_1-3 columns. But no. We haven't.
The RevPart in MIG_3 depends only on the firs Revision value.
+------+----------+------------+-------+-------+-------+
| Name | Revision | MaxInGroup | MIG_1 | MIG_2 | MIG_3 |
+------+----------+------------+-------+-------+-------+
| A | ="" | 1,01 | 1,01 | 1,01 | 1 |
| A | a | 1,01 | 1,01 | 1,01 | 1 |
| B | ="" | 3 | 3 | 3 | 3 |
| C | ="" | 4,01 | 4,01 | 4,01 | 4 |
| C | a | 4,01 | 4,01 | 4,01 | 4 |
+------+----------+------------+-------+-------+-------+
Versus
+------+----------+------------+-------+-------+-------+
| Name | Revision | MaxInGroup | MIG_1 | MIG_2 | MIG_3 |
+------+----------+------------+-------+-------+-------+
| A | a | 1,01 | 1,01 | 1,01 | 1,01 |
| A | a | 1,01 | 1,01 | 1,01 | 1,01 |
| B | ="" | 3 | 3 | 3 | 3,01 |
| C | ="" | 4,01 | 4,01 | 4,01 | 4,01 |
| C | a | 4,01 | 4,01 | 4,01 | 4,01 |
+------+----------+------------+-------+-------+-------+
Note: ="" means there is a blank string in the cell (formula ="")