質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.51%

Q&A

3回答

1976閲覧

エクセル 数式手入力の簡素化をしたい

meg.excel

総合スコア8

0グッド

0クリップ

投稿2016/03/30 13:43

編集2022/01/12 10:55

エクセルで、横並びの見積もりの推移表のようなものを作っています。

sheet1に、見積もり推移表(見積もり1回目、2回目・・・と、横並びにする)があり、sheet2に1回目の見積もりデータ、sheet3に2回目の見積もりデータが張り付けてあります。

現状→
①sheet1のA1セルに='sheet2'!$B$2という数式があり、これを隣のセルB1セルに貼り付け='sheet3'!$B$2となるように、シート名を手入力直しています。
②sheet1のA1セルに='sheet2'!$B$2という数式があり、これを下のセルA2セルに貼り付け='sheet2'!$C$2となるように、列を手入力直しています。

こうしたい→
上記①②セルへの数式の入力を簡単にしたいです。シート名(上記①),及び列(上記②)を手入力で変更する手間を省きたいです。

追加
すみません。上記②について、詳細です。すみません。
A1セルに='sheet2'!$B$2、
A2セルに='sheet2'!$B$3、
A3セルに='sheet2'!$C$2、
A4セルに='sheet2'!$C$3、
A5セルに='sheet2'!$D$2、
A6セルに='sheet2'!$D$3、
という、規則で入れていきたいです。。
A1とA2はドラッグすれば出来ますが、それA3からA6までは、手入力以外で方法はありますでしょうか。。

エクセル2012です。
宜しくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Ryo

2016/03/30 14:30

使えそうな関数を探して、試してみましたか? 現状の質問内容では、「自分で考えてもよく分からないから、後よろしく。」と受け取れます。 個人的おすすめは [Office TANAKA](http://officetanaka.net/)
meg.excel

2016/03/30 14:58

Ryo様 アドバイスありがとうございます。自分でも色々やってみたつもりだったのですが、ここへ質問してしまいました。はじめてこちらのサイトを拝見したので、質問が不適切でありましたら、申し訳ございませんでした。。。 上記のOfficetanakaも、拝見してみます。ありがとうございました。
guest

回答3

0

期待する動作はこんなかんじでしょうか?

奇数行のセル:(A1,A3,A5…,B1,B3…)

=INDIRECT("Sheet"&(COLUMN()+1)&"!"&CHAR(INT(ROW()/2)+65)&"$2")

偶数行のセル:(A2,A4,A6…,B2,B4…)

=INDIRECT("Sheet"&(COLUMN()+1)&"!"&CHAR(INT(ROW()/2)+64)&"$3")

投稿2016/03/31 04:09

jawa

総合スコア3013

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

meg.excel

2016/04/05 12:46

jawa様 ありがとうございました。返答が遅くなり申し訳ございません。上記の通りセルに入れても、エラーになってしまい数式の入力が完了できません。INDIRECT(の後の、sheet部は、sheet名でよろしかったでしょうか。
jawa

2016/04/06 00:27

少し解説すると、INDIRECTは文字列をセル参照に変換するExcel関数です。 今回は "Sheet"&(COLUMN()+1)&"!"&CHAR(INT(ROW()/2)+65)&"$2" の部分で列番号と行番号から参照セルを表す文字列を作成し、それをINDIRECTで参照しています。 たとえば上記の数式をセルA3に記述すると、COLUMN()は1、ROW()が3になるので、"Sheet" & (1+1) & "!" & CHAR(1 + 65) & "$2" となり、全部組み合わせると"Sheet2!C$2"の文字列となります。 わかりやすく動きをみるためには一度INDIRECTを外して試してみるといいかもしれません。 質問ではSheet2、Sheet3を参照するということでしたので上記の式を提示しましたが、もしシート名に連番の数字がついていないのであればもう一工夫必要になります。
guest

0

=INDIRECT("Sheet"&(ROW()+1)&"!"&CHAR(COLUMN()+64)&"$2")

投稿2016/03/30 14:44

kei344

総合スコア69357

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

meg.excel

2016/04/05 12:48

kei344様 ありがとうございました。返答が遅くなり申し訳ございません。上記の通りセルに入れても、エラーになってしまい数式の入力が完了できません。INDIRECT(の後の、sheet部は、sheet名でよろしかったでしょうか。
guest

0

投稿2016/03/30 14:36

umed0025

総合スコア851

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.51%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問