特定の文字列から文字を組み替えてランダムな文字列を作り直す、Excelでアナグラムを自動生成する方法です。
成果物
data:image/s3,"s3://crabby-images/6625d/6625dc86607e6e166a714b2484fd8176347c4345" alt="excel アナグラム11"
このように、元の文字列を組み替えた文字列を自動生成する状態を目指します。
アナグラムの生成
文字の抽出
data:image/s3,"s3://crabby-images/2236c/2236c0a4470d5b1cfa4965bc50106d52afb27828" alt="excel アナグラム1"
C1にアナグラムしたい文字列を置きます。日本語でも英語でも数字でもOKです。
data:image/s3,"s3://crabby-images/795bb/795bb9552f22d87e368e65b3ed185d66224f9817" alt="excel アナグラム2"
C2セルに
=Mid($C$1,Row()-1,1)
と記述し、data:image/s3,"s3://crabby-images/da15d/da15df743a6e7ebeff3be49773f5a9cc38b68136" alt="excel アナグラム3"
これを下のほうまでオートフィルで伸ばします。元の文字数を超えた部分は何も表示されません。
乱数の生成
data:image/s3,"s3://crabby-images/6e82d/6e82d00a44ad9916f4726f303e5f80d9b47d6cca" alt="excel アナグラム4"
A2セルには
=If(C2 ="","",Rand())
と記述し、文字を組み替えるための乱数を発生させます。data:image/s3,"s3://crabby-images/ddbec/ddbec56bb79ebfdfee2b82294261c9e4396fbbaa" alt="excel アナグラム5"
同様に下のほうまで伸ばします。
乱数を順序化
data:image/s3,"s3://crabby-images/55dce/55dce65419291cc9af07d4fceaead683fd5f4689" alt="excel アナグラム6"
さらにB2セルも
=IfError(Rank.Eq(A2,A:A),"")
と入力して、data:image/s3,"s3://crabby-images/c39f6/c39f6136eef781acef234bd9dc9fd6ae61926dd1" alt="excel アナグラム7"
やはり下のほうへと伸ばします。
抽出した文字の組み替え
data:image/s3,"s3://crabby-images/26510/265105b7a16a31a00055c7070e9c6de15b8bf03f" alt="excel アナグラム12"
D2セルに
=IfError(VlookUp(Row()-1,B:C,2,FALSE),"")
と入力し、data:image/s3,"s3://crabby-images/a1522/a152284d1deb6cfd34b43dac8704890d4d64b8ba" alt="excel アナグラム8"
例によって伸ばします。
文字列の結合(完成)
data:image/s3,"s3://crabby-images/a618a/a618a93b2e7fcbd2f001fc0de51b95cc71ae86df" alt="excel アナグラム9"
最後にアナグラムを出力したいセルに
=Concat(D2:D1000)
と入力してEnterを押します(数字は適当です)。data:image/s3,"s3://crabby-images/1ff01/1ff015fb300d3e80d9202dd55281f3c563d2c063" alt="excel アナグラム concat"
文字列内の文字がランダムに並び替えされます。
F9を押すたびに再計算が入りアナグラムが変わります。
F9を押すたびに再計算が入りアナグラムが変わります。
data:image/s3,"s3://crabby-images/70932/709322ce818b853f5ea05561aa862d95297446b7" alt="excel アナグラム10"
気に入ったものがあったら、値をコピーしてただの文字列に変換しておきます。
アナグラムする文字列の変更
data:image/s3,"s3://crabby-images/c5e2e/c5e2ef531ad43ec8ebc8d815c8d6f5c9115eb437" alt="excel アナグラム14"
C1の文字列を変更すれば、出力されるアナグラムも変更されます。
data:image/s3,"s3://crabby-images/aa8c2/aa8c217502345dde35f8d59e3f12ccd41e8e5e4c" alt="excel アナグラム13"
もし長い文字列がうまく変換できない場合は、
data:image/s3,"s3://crabby-images/9e833/9e833a880655a14b4e4f851f03235b5f4defdf75" alt="excel アナグラム15"
A~D列が足りてないので、オートフィルで下に延長してあげてください。
別の方法、関連記事
使っている関数はこの記事とほぼ同一なので、解説は省略します。
何回も並べ替えしないなら、一文字ずつ抽出して並べ替えしたものを結合するほうが簡単です。
data:image/s3,"s3://crabby-images/31653/316531461c1816cd7c63617c9270240dc47090c3" alt=""
Excel(エクセル):ランダム、乱数
Excelの乱数、ランダム関連操作、関数等まとめです。
乱数の作成
関数で乱数を求める場合、Rand関数(0~1の乱数)またはRandBetween関数(指定範囲の整数)を用います。
もしビンゴで使うような重複...
コメント