Excelを用いて表を製作しています。
A1に あいうえおかきくけこ
A2に さしすせそたちつてと
A3に なにぬねのはひふへほ
以下同様(本来は規則的な文字列ではなく不規則な13ケタの数字です)
このように入力されているものをMID関数で1つのセルに1文字ずつ表示しています。
B1=MID(A1,1,1) C1=MID(A1,2,1) D1=MID(A1,3,1)・・・
(B1 あ C1 い D1 う E1 え ・・・)
これを2行に分け、
B1 あ C1 い D1 う E1 え F1 お
B2 か C2 き D2 く E2 け F2 こ
B3 さ C3 し D3 す E3 せ F3 そ
B4 た C4 ち D4 つ E4 て F4 と
以下同様
と表示したいのですが、以下のような数式が延々と続く形になります。
B1=MID(A1,1,1) C1=MID(A1,2,1) D1=MID(A1,3,1)・・・
B2=MID(A1,6,1) C2=MID(A1,7,1) D2=MID(A1,8,1)・・・
B3=MID(A2,1,1) C3=MID(A2,2,1) D3=MID(A2,3,1)・・・
B4=MID(A2,6,1) C4=MID(A2,7,1) D4=MID(A2,8,1)・・・
これをタテに見て、MID関数の
文字列は A1 A1 A2 A2 A3 A3・・・ と2つ連続で表示しながら1つずつ増加
開始位置は 列により 1,6,1,6・・・ 2,7,2,7・・・ 3,8,3,8・・・と2つの数字の繰り返し
文字数は 全て変わらず1のまま
これを全て手打ちできればよいのですが、膨大な量があるのでオートフィル等を利用して簡単に数式を作るためにはどうしたらよいでしょうか?
素人が調べながらなんとか作った数式なので、根本的なやり方を変えたほうがよければご助言をいただけると助かります。
よろしくお願いいたします。
No.1ベストアンサー
- 回答日時:
こんにちは
A列は13文字ということなので、B2=MID(A1,6,1)と6番目でいいのか、なんだか疑問ですが・・・
とりあえずご質問文通りとして、B1に
=MID(INDIRECT("A"&INT(ROW(A2)/2)),5*MOD(ROW(A2),2)+COLUMN(A1),1)
を入力して、右側、下側に必要な範囲にフィルコピーでどうでしょうか?
ありがとうございます。
元データは13文字なのですが、実際には
1行目 1~4文字 (5文字目は非表示)
2行目 6~13文字
と部分的にピックアップしているため6番目に設定していました。
混乱させてしまい申し訳ありません。
おかげさまでコピーして希望通りの表を作ることが出来ました。
ありがとうございました。
No.2
- 回答日時:
セルの行や列の番号を値として使う関数がある。
・COLUMN関数は列を
・ROW関数は行を
それぞれ値として返す。
=COLUMN(A1)
とB2セルに入力して、D3セルまでコピーすると
B2セル =COLUMN(A1)
B3セル =COLUMN(A2)
C2セル =COLUMN(B1)
C3セル =COLUMN(B2)
D2セル =COLUMN(C1)
D3セル =COLUMN(C2)
と数式中の参照セルが変わり、返ってくる値は
B2セル =COLUMN(A1) →1
B3セル =COLUMN(A2) →1
C2セル =COLUMN(B1) →2
C3セル =COLUMN(B2) →2
D2セル =COLUMN(C1) →3
D3セル =COLUMN(C2) →3
となる。
同様にROW関数でも
B2セル =ROW(A1) →1
B3セル =ROW(A2) →2
B4セル =ROW(A3) →3
C2セル =ROW(B1) →1
C3セル =ROW(B2) →2
C4セル =ROW(B3) →3
となる。
応用として、これにMOD関数やINT関数を組み合わせるという手法もある。
=MOD(ROW(A100),3)
とすると、100を3で割った余りを値として得られる。
0、1、2の値を繰り返して使いたいときに便利に利用できる。
※=MOD(ROW(A100),3)+1 とすると、1,2,3の値を繰り返し…。
=INT(ROW(A100)/3)
ならば、100を3で割った商が値として得られる。
3つ同じ値を繰り返し、1つ増やしたものをまた3つ繰り返す…という使い方になる。
0,0,1,1,1,2,2,2,3,3,3,…のような値を得られる
※=INT((ROW(A100)+2)/3) とすると、1,1,1,2,2,2,3,3,3,…
これらを工夫してみてください。
面倒ですが、意外と簡単にできたりします。
ありがとうございます。
応用の部分の組み合わせ説明が分かり易く大変参考になりました。
今回は最初に回答を頂いた方をベストアンサーに選ばせて頂きましたが、
今後も様々な表を作る機会がありますので参考にさせて頂きます。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) エクセルの数式で教えてください。 1 2023/07/31 15:49
- その他(Microsoft Office) IF関数について教えてください 2 2022/05/10 13:31
- その他(音楽・ダンス・舞台芸能) 音階についての簡単な質問です 3 2023/04/06 17:19
- Excel(エクセル) EXCEL 行内のデータを2行に分けて、表を作り直したいのです。教えてください。 5 2023/06/25 14:00
- Excel(エクセル) エクセルの関数式を教えてください。 2 2022/11/29 21:09
- Excel(エクセル) エクセルで、 A1セルに「A」という値、 B1セルに「B」という値が入っています。 どちらも表示形式 5 2023/02/22 23:05
- Excel(エクセル) エクセル関数教えてください 3 2022/06/21 10:22
- Visual Basic(VBA) ローマ字、ハイフン付きの並び替え ローマ字抽出方法 Excelマクロ 4 2022/04/01 14:10
- Excel(エクセル) Excel表示形式 2 2022/09/09 09:57
- Excel(エクセル) Excelの空文字判定について 7 2023/01/06 13:25
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
【エクセル】IF関数 Aまたは...
-
対象セル内(複数)が埋まった...
-
エクセルで指定したセルのどれ...
-
EXCEL VBA セルに既に入...
-
エクセル 足して割る
-
excelのCOUNTIF関数で、『範囲=...
-
【Excel】 セルの色での判断は...
-
貼り付けで複数セルに貼り付けたい
-
セルをクリック⇒そのセルに入力...
-
Excelで数式内の文字色を一部だ...
-
エクセルのセルの枠を超えて文...
-
エクセル オートフィルタで絞...
-
Excelでのコメント表示位置
-
(Excel)数字記入セルの数値の後...
-
Excelで住所を2つ(町名迄と番...
-
セルの高さ(行高)を求めるには?
-
エクセルの一つのセルに複数の...
-
VBAで特定の文字が入力されたセ...
-
Excelで条件をつけてハイパーリ...
-
Excelの関数で、性別が男なら『...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルで指定したセルのどれ...
-
【エクセル】IF関数 Aまたは...
-
対象セル内(複数)が埋まった...
-
エクセル 足して割る
-
Excelで数式内の文字色を一部だ...
-
貼り付けで複数セルに貼り付けたい
-
Excelでのコメント表示位置
-
セルをクリック⇒そのセルに入力...
-
EXCEL VBA セルに既に入...
-
excelのCOUNTIF関数で、『範囲=...
-
【Excel】 セルの色での判断は...
-
エクセル オートフィルタで絞...
-
エクセルのセルの枠を超えて文...
-
(Excel)数字記入セルの数値の後...
-
Excelで、「特定のセル」に入力...
-
エクセルの一つのセルに複数の...
-
複数のセルのいずれかに数字が...
-
excelの特定のセルの隣のセル指...
-
数式を残したまま、別のセルに...
-
ハイパーリンクの参照セルのズ...
おすすめ情報