data:image/s3,"s3://crabby-images/42059/42059e551321eacaf692c3771f4fcb2952e0ce67" alt="見出し画像"
行方向のみに条件が並ぶ表を、行・列方向に条件が並ぶ表に変換する
今回は、こちらの話題の逆変換です。
こんな感じの、左側に条件が並んでいる一覧表があるとします。
例-1
data:image/s3,"s3://crabby-images/599dc/599dc220e262faf5da50043af7e6ea722004db62" alt=""
例-2
data:image/s3,"s3://crabby-images/c3e51/c3e51c61c381ac11e47939cecc306fc19390510d" alt=""
これを、タイトル行・列の2方向に条件が並ぶ表に変換します。
data:image/s3,"s3://crabby-images/f053d/f053d0dbbdf587d2f1c6183ea2d092e38054097e" alt=""
「例-1」のような場合
(1) 1つめの条件を行方向に並べ替える
重複をなくす数式「unique()」を使えば1発で処理できる
data:image/s3,"s3://crabby-images/3c7e1/3c7e113f80915cc379c3e725ddeb0ffc1ebba4a6" alt=""
引数には、条件の範囲(赤色の範囲)を指定する
=unique([条件の範囲])
すると、次のような感じに変換できる
data:image/s3,"s3://crabby-images/62997/6299748b0d1431de5d63c259c74cf934a56dcd5b" alt=""
(2) 2つめの条件を列方向に並べ替える
(1)の処理に、転置するための数式「transpose()」を付け加えて使う
data:image/s3,"s3://crabby-images/6feaf/6feaf1dc13844e72e230d0f7ff0a909bc598021e" alt=""
引数には、条件の範囲(青色の範囲)を指定する
=transpose(unique([条件の範囲]))
すると、次のような感じに変換できる
data:image/s3,"s3://crabby-images/4ea1b/4ea1b43d3aa7ce8b88e38c4cb166674bc0f34048" alt=""
(3) 対応値を行・列方向に整理しなおす
「tocol()」の逆変換をする数式「wraprows()」を使う
data:image/s3,"s3://crabby-images/7d43e/7d43e8a8af77e21ed48232019e32895379c2cc8c" alt=""
引数には、条件の範囲(黄色の範囲)と、列数を入れる
=wraprows([対応値の範囲],[列数])
すると、次のような感じに変換できる
data:image/s3,"s3://crabby-images/46d76/46d76fd6a3f17921dfe34fceeab3ddb72093d548" alt=""
「例-2」のような場合
(1) 条件を分解し、その1つめを行方向に並べ替える
まず、文字列をセル分割する数式「split()」を使う
そのあと、セル列を取り出す数式「index()」を合わせて使う
(splitの第1引数には分割対象文字列、第2引数には区切り文字を入れ、
indexの第1引数には行番(今回は空欄)、第2引数には列番を入れる)
その上で、重複をなくす数式「unique()」を使う
data:image/s3,"s3://crabby-images/a90f2/a90f247d5dec1b44cc1d2aad58d0ab66c8431b8e" alt=""
引数には、条件の範囲(緑色の範囲)を指定する
(「"-"」のところは、区切り文字に応じて変わってきます)
=unique(index(split([条件の範囲],"-"),,1))
すると、次のような感じに変換できる
data:image/s3,"s3://crabby-images/2bf3a/2bf3abd43761a3bb88bb9e27448c6c58b8a44d14" alt=""
(2) 条件を分解し、その2つめを列方向に並べ替える
(1)の処理に、転置するための数式「transpose()」を付け加えて使う
data:image/s3,"s3://crabby-images/a90f2/a90f247d5dec1b44cc1d2aad58d0ab66c8431b8e" alt=""
引数には、条件の範囲(緑色の範囲)を指定する
(「"-"」のところは、区切り文字に応じて変わってきます)
=transpose(unique(index(split([条件の範囲],"-"),,2)))
すると、次のような感じに変換できる
data:image/s3,"s3://crabby-images/5e013/5e0134b10e2c546f2fb47c752ca3120edd25404c" alt=""
(3) 対応値を行・列方向に整理しなおす
上記の、「例-1」のような場合の(3)と同じ
以上のことを組み合わせれば、次のような表ができあがります。
機会があれば、せひ活用していきましょう!
data:image/s3,"s3://crabby-images/f053d/f053d0dbbdf587d2f1c6183ea2d092e38054097e" alt=""