Excel VBA質問箱 IV

当質問箱は、有志のボランティア精神のおかげで成り立っています。
問題が解決したら、必ずお礼をしましょうね。
本サイトの基本方針をまとめました。こちら をご一読ください。

投稿種別の選択が必要です。ご注意ください。
迷惑投稿防止のため、URLの入力を制限しています。ご了承ください。


46001 / 76735 ←次へ | 前へ→

【35715】Re:複数条件に当てはまる時に値を返す
回答  Kein  - 06/3/10(金) 20:36 -

引用なし
パスワード
   >条件を満たすセルを3つ作る
例えば A1:A3 に入力された値で・・ということなら、先のやり方では条件分岐の
ネストが深くなりすぎて、極端に可読性が悪くなってしまいますから「A1,A2,A3の
値を & で連結したときの全パターン」によって、一回の Select Case で対応できる
ように改造します。その場合先の y / z の結果は、予め算出済みの定数としてしまい、
コードではそれに C1 の値をかけるだけとします。
即ち

Private Sub Worksheet_Change(ByVal Target As Range)
  Dim x As Long, y As Long
  Dim St As String

  If Intersect(Target, Range("A1:A3")) Is _
  Nothing Then Exit Sub
  If Target.Count > 1 Then Exit Sub
  x = Range("C1").Value
  St = Range("A1").Text & Range("A2").Text & _
  Range("A3").Text
  Select Case St
   Case "ピーマン東京3月10日": y = x * ? '?は定数

   以下、全てのパターンを書き出す
  End Select
  With Application
   .EnableEvents = False
   Range("C3").Value = y
   .EnableEvents = True
  End With
End Sub

というようなコードになりますが、他のやり方は分かりません。

0 hits

【35695】複数条件に当てはまる時に値を返す 青たん 06/3/10(金) 15:15 質問
【35697】Re:複数条件に当てはまる時に値を返す 青たん 06/3/10(金) 15:27 質問
【35702】Re:複数条件に当てはまる時に値を返す Kein 06/3/10(金) 16:20 回答
【35706】Re:複数条件に当てはまる時に値を返す 青たん 06/3/10(金) 17:48 質問
【35715】Re:複数条件に当てはまる時に値を返す Kein 06/3/10(金) 20:36 回答
【35728】Re:複数条件に当てはまる時に値を返す 青たん 06/3/11(土) 10:41 お礼
【35731】再びすみません。 青たん 06/3/11(土) 12:20 質問
【35732】Re:再びすみません。 Kein 06/3/11(土) 15:13 回答
【35736】Re:再びすみません。 青たん 06/3/11(土) 16:27 お礼

46001 / 76735 ←次へ | 前へ→
ページ:  ┃  記事番号:
2610219
(SS)C-BOARD v3.8 is Free