Excel VBA質問箱 IV

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

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


49252 / 76735 ←次へ | 前へ→

【32401】Re:ユーザー定義関数で
発言  ichinose  - 05/12/14(水) 9:45 -

引用なし
パスワード
   ▼まさ さん:
おはようございます。

>お二方、早速のご提案ありがとうございます。
>しょっぱなから細かい条件を書くと、お伝えしにくいと思い
>省略した部分をさらに質問したいと思います。
これは、最初から記述してください。
だって、仕様が大きく違っていますからね!!


Chkvalueを以下のように変更しました。
'============================================================
Function chkvalue(rng As Range, ParamArray f_value()) As Variant
'機能  : 指定されたセル範囲に指定されたデータの有無を調査する
'入力  : rng --- 調査するセル範囲
'      f_value()- 有無を調査するデータ群(3の倍数分の要素が必要)
'     連続する3つ要素をパックデータとします。第一、第二要素は検索データ
'     第三要素は△判定をするか否かのフラグ 0-△判定しない 1-△判定する
'出力  : chkvalue---○--f_value()の全てのデータがセル範囲に存在する
'            △--f_value()のパックデータ第二、第一とこの純情で連続して存在した場合
'            ×--f_value()の中の検索パックデータのいずれにも属さない場合
'記述例 : =chkvalue(a1:c3,1,2,0) セル範囲A1:C1の中に1,2の両方が1,2の順序で存在するか調査する
'      =chkvalue(a1:c3,1,2,0,0,3,1)
'      セル範囲A1:C1の中に1,2の両方が1,2の順序で存在するか調査する
'      又、0,3の両方が0,3の順序で存在するか調査し、且つ、3,0で連続して存在した場合は△判定とする
  Dim idx As Long
  chkvalue = "×"
  Dim chkstr As Variant
  chkstr = ""
  For idx = 1 To rng.Count
    chkstr = chkstr & "(" & rng.Cells(idx).Value & ")"
    Next
'  MsgBox chkstr
  Dim regEx
  Set regEx = CreateObject("VBScript.RegExp")
  ' 正規表現を作成します。
  regEx.IgnoreCase = True ' 大文字と小文字を区別しないように設定します。
  regEx.Global = True  ' 文字列全体を検索するように設定します。
  For idx = LBound(f_value()) To UBound(f_value()) Step 3
    regEx.Pattern = "\(" & f_value(idx) & "\).*\(" & f_value(idx + 1) & "\).*"
'    MsgBox regEx.Pattern
    
    If regEx.test(chkstr) Then
      chkvalue = "○"
      Exit For
    Else
      If f_value(idx + 2) = 1 Then
       regEx.Pattern = "\(" & f_value(idx + 1) & "\)\(" & f_value(idx) & "\).*"
       If regEx.test(chkstr) Then
         chkvalue = "△"
         Exit For
         End If
        End If
      End If
   Next idx
  Set regEx = Nothing
End Function


1    2    3   
3    8    0   
2    10   1   
6    1    2   
−1   1    0   
0    1    8   
30   50   0

このデータがセルA1からC7に入っていた時、

1と2は○
2と1は×
1と3は○
3と1は△
0と2は○
2と0は△
0と1は○
1と0は△
これ以外は×

という条件だとすると
「=chkvalue(A1:C1,1,2,0,1,3,1,0,1,1,0,2,1)」
なんて指定してフィル操作してください。
上記のデータの判定が

×
×



×
となります。
但し、セルにあるデータには数値という想定です。
確認してみてください。

0 hits

【32387】ユーザー定義関数で まさ 05/12/13(火) 20:31 質問
【32390】Re:ユーザー定義関数で kobasan 05/12/13(火) 21:28 回答
【32391】Re:ユーザー定義関数で ichinose 05/12/13(火) 21:43 発言
【32394】Re:ユーザー定義関数で まさ 05/12/13(火) 22:32 質問
【32401】Re:ユーザー定義関数で ichinose 05/12/14(水) 9:45 発言
【32479】Re:ユーザー定義関数で まさ 05/12/15(木) 18:39 質問
【32484】Re:ユーザー定義関数で kobasan 05/12/15(木) 21:24 発言
【32486】Re:ユーザー定義関数で ichinose 05/12/15(木) 22:27 発言

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