• ベストアンサー

エクセルVBAを使ってデータの抽出をしたいのですが

タンク容量のデータベースがあります。(以下のような)    A   B   C......←タンクNo 0  100  200  500 ..... 2  90  180  460  ...... 4  80  160   420  ..... 6   70  140   400 .....  ・ ・ ・ ↑タンク上部からの空寸 このようなデータからたとえば、タンクBの160は空寸が4ですが、この空寸4を抽出するにはどうすればいいのか教えてください。 ちなみに、データはシート2にあり、シート1のA1セルにタンクN0、B1セルに容量を入力し、コマンドボタンを押すとC1セルに対応する空寸がでるようにしたいのですが。。 また、容量はぴったり一致するときもありますが、無いときは最も近い値の空寸を持ってきたいのです。 どうか、よろしくお願いします。

質問者が選んだベストアンサー

  • ベストアンサー
  • maruru01
  • ベストアンサー率51% (1179/2272)
回答No.3

再びmaruru01です。 まず、Sheet2の表の位置を確認したいのですが、 A1は空白で、A2~縦方向にA1225までに「空寸」、 逆に、B1~横方向にAP1までに「タンクNo」となっていますか? つまり、容量はB2~AP1225までに入力されていることになります。 それなら、No.1の補足欄の数式でいいはずですが。 あと、MATCH関数では、タンクNoの位置を検索しています。 したがって、データに関係なく、第2引数は「Sheet2!$1:$1」のままにしておいて下さい。

nakkya
質問者

お礼

参考にさせて頂いて、何とか解決できました。 ありがとうございました。 結局、VBAでやってみました。

その他の回答 (2)

  • imogasi
  • ベストアンサー率27% (4737/17069)
回答No.2

(データ)Sheet2のA1:D5 A  B  C. 0 100 200 500 2 90 180 460 4 80 160 420 6 70 140 400 (指定) B9セル (VBA) Sub test01() Worksheets("sheet2").Select Select Case Cells(9, 2) 'B9セル Case Is < 100 c = 2 Case Is < 200 c = 3 Case Is < 500 c = 4 End Select MsgBox c For i = 1 To 10 If Cells(i, c) < Cells(9, 2) Then If Cells(9, 2) - Cells(i, c) > Cells(i - 1, c) - Cells(9, 2) Then MsgBox Cells(i - 1, c) Else MsgBox Cells(i, c) End If Exit Sub Else End If Next i End Sub (テスト) 94の時2 101の時6 171の時2 490のとき0 (お詫び) この解答はB列の最低が100を越える、またC列の最低 (最下行)が200を越えることを前提にしています。 また急いだため、指定を同じシートのB9に設定して手抜きをしています。ヒントに使ってください。 またテストが十分でありませんことをお詫びします。 上記仮定が不可の場合は、おっしゃって頂ければ考えなおします。

nakkya
質問者

補足

お返事ありがとうございます。maruru01さんが教えてくれるワークシート関数でやってみようかと思っていますが、VBAも勉強したいと思っているものですから、教えてください。 Worksheets("sheet2").Select Select Case Cells(9, 2) 'B9セル Case Is < 100 c = 2 Case Is < 200 c = 3 Case Is < 500 c = 4 ですが、タンク容量のデータシートにはタンクの番号が200本以上あります。1から200番まで整理されて並んでいるわけでなく番号が不揃いで1052や12、502、500、821といったようにランダムにまた抜けた番号もあります。また今回はシート2のタンクのデータで対処できるのですが今後シート3やシート4にもタンク容量のデータがありそちらも利用できたらとも思っています。 説明不足で申し訳ありませんがよろしくお願いいたします。

  • maruru01
  • ベストアンサー率51% (1179/2272)
回答No.1

こんにちは。maruru01です。 VBAでなくても、ワークシート関数でも出来ます。 シート1のC1に、 =IF(ISERROR(MATCH($A$1,Sheet2!$1:$1,0)),"",INDEX(Sheet2!$A:$A,MIN(IF(ABS(OFFSET(Sheet2!$A$2:$A$5,0,MATCH($A$1,Sheet2!$1:$1,0)-1)-$B$1)=MIN(ABS(OFFSET(Sheet2!$A$2:$A$5,0,MATCH($A$1,Sheet2!$1:$1,0)-1)-$B$1)),ROW(Sheet2!$A$2:$A$5))))) と入力して、[Ctrl]+[Shift]+[Enter]で確定します。 (数式の両端に「{}」が付いて、配列数式になります。) なお、Sheet2のデータ範囲は2~5行なので、適宜変更して下さい。 また、シート1のB1の値が2つのデータの中間の場合は、上の行が優先されます。 例えば、「B」で「170」なら、「3」ではなく「2」になります。

nakkya
質問者

補足

返事が遅くなってしまい申し訳ありません。 maruru01さん、いつも教えていただいてありがとうございます。 MATCH関数がよくわからないのですが、MATCH($A$1,Sheet2!$1:$1,0)の$1:$1はどういう意味なのでしょうか? タンクのデータはA1からAP1225に入っているのですが$1:$1の部分をA1:AP1225に変えればいいのですか? また、”Sheet2のデータ範囲は2~5行なので、適宜変更して下さい。”ということだったので最初 {=IF(ISERROR(MATCH($A$1,Sheet2!$1:$1,0)),"",INDEX(Sheet2!$A:$A,MIN(IF(ABS(OFFSET(Sheet2!$A$2:$A$1225,0,MATCH($A$1,Sheet2!$1:$1,0)-1)-$B$1)=MIN(ABS(OFFSET(Sheet2!$A$2:$A$1225,0,MATCH($A$1,Sheet2!$1:$1,0)-1)-$B$1)),ROW(Sheet2!$A$2:$A$1225))))) }としましたがだめでしたどこがいけないのでしょうか? 一つ一つ解釈しながら勉強させて頂いてます。すいませんが、よろしくおねがいいたします。

関連するQ&A

専門家に質問してみよう