![Excel で、姓、名としてフォーマットされている名前を、名の頭文字とアンダースコアの姓としてフォーマットする方法はありますか?](https://rvso.com/image/1672438/Excel%20%E3%81%A7%E3%80%81%E5%A7%93%E3%80%81%E5%90%8D%E3%81%A8%E3%81%97%E3%81%A6%E3%83%95%E3%82%A9%E3%83%BC%E3%83%9E%E3%83%83%E3%83%88%E3%81%95%E3%82%8C%E3%81%A6%E3%81%84%E3%82%8B%E5%90%8D%E5%89%8D%E3%82%92%E3%80%81%E5%90%8D%E3%81%AE%E9%A0%AD%E6%96%87%E5%AD%97%E3%81%A8%E3%82%A2%E3%83%B3%E3%83%80%E3%83%BC%E3%82%B9%E3%82%B3%E3%82%A2%E3%81%AE%E5%A7%93%E3%81%A8%E3%81%97%E3%81%A6%E3%83%95%E3%82%A9%E3%83%BC%E3%83%9E%E3%83%83%E3%83%88%E3%81%99%E3%82%8B%E6%96%B9%E6%B3%95%E3%81%AF%E3%81%82%E3%82%8A%E3%81%BE%E3%81%99%E3%81%8B%3F.png)
私の Excel スプレッドシートは別のタブから名前を取得し、Smith, John としてフォーマットされています。その名前を使用する Vlookup 数式があるため、手動で処理せずに再フォーマットすることはできません。別のタブには、名前が j_smith としてフォーマットされているデータがあり、このタブの同じ領域に入力するための Vlookup 数式が必要です。名前が 500 近くあるため、Smith, John を j_smith に変換して、全員に手動で略語を入力しなくても済むようにする数式があるかどうか知りたいです。
答え1
答え2
答えはいくつかあります。簡単なものもあれば、そうでないものもあります。おそらく、LEFT、MID、FIND 関数を組み合わせて使用します。& を使用していつでも文字列を作成できます。
- MID(文字列、開始点、文字数)
- したがって、セル A1 の 4 番目の文字が必要な場合は、=MID(A1, 4, 1) を使用します。
問題は、どの文字から始めればよいかわからないことです。そこで、これを FIND と組み合わせます。
- FIND(検索する文字列、検索対象)
- スペースの後の文字が必要なことはわかっているので、=FIND(A1, " ")+1 は、1 番目の名前の最初の文字に置きます。1 番目の名前の頭文字を取得するには、上記の MID 関数の 4 の代わりに FIND を使用します。
姓の場合は、LEFT 関数を使用できます。
- LEFT(テキスト文字列、文字数)
- 繰り返しになりますが、姓の長さはわかりませんが、FIND 関数を使用するとスペースがどこにあるかがわかります。
そして、& を使用すると、いつでも物事をまとめることができます。
- ="こんにちは" & " " & "世界"
最終結果は次のようになります。
- =MID(A1, FIND(A1, " ")+1, 1) & "_" & LEFT(A1, FIND(A1, " "))