Excel VBA質問箱 IV

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

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


71874 / 76738 ←次へ | 前へ→

【9357】Re:ユニークな数値を数えたい。
回答  りん E-MAIL  - 03/11/30(日) 17:54 -

引用なし
パスワード
   まゆん さん、こんばんわ。

>あの〜。恐れ入りますもうひとつ質問させてください。
>ExcelのCellの中に下記のような表があると例えます。

>A1  データ
>A2 001
 <<略>>
>A9 006
>A10 007

>上記の表を例にすると答えは6です。
だとして。

Sub Test()
  With Range("A1:A10")
   .AdvancedFilter Action:=xlFilterInPlace, Unique:=True
   'Rangeは分断されていると一番上だけしかCountで返さなくなるので
   'Areasで全部チェックして足していく
   For Each c In .SpecialCells(xlCellTypeVisible).Areas
     RR& = RR& + c.Rows.Count
   Next
   '1行目はタイトル行なのでデータの行数は -1
   MsgBox RR& - 1, vbInformation, "Unique"
  End With
 
End Sub

ベタに数えていく場合
Sub test()
  Dim Rmax&, Rpos&, Flg As Boolean
  Rmax& = 10 'A10まで検索するとして
  Rpos& = 0
  ReDim cdat(1 To Rmax&) As Variant '内容保管用
  '
  For RR& = 2 To Rmax&
   With Cells(RR&, 1)
     If .Value <> "" Then
      Flg = True
      For NN& = 1 To Rpos&
        If cdat(NN&) = .Value Then
         Flg = False: Exit For
        End If
      Next
      'チェック後重複が無ければ配列に入れる
      If Flg = True Then
        Rpos& = Rpos& + 1
        cdat(Rpos&) = .Value
      End If
     End If
   End With
  Next
  MsgBox Rpos&, vbInformation, "Unique"
  Erase Cdat
End Sub

ichinoseさんの配列数式も面白そうですね。

0 hits

【9348】ユニークな数値を数えたい。 まゆん 03/11/30(日) 15:45 質問
【9349】Re:ユニークな数値を数えたい。 INA 03/11/30(日) 16:06 回答
【9355】Re:ユニークな数値を数えたい。 まゆん 03/11/30(日) 16:58 質問
【9356】Re:ユニークな数値を数えたい。 INA 03/11/30(日) 17:51 回答
【9360】Re:ユニークな数値を数えたい。 INA 03/11/30(日) 18:02 回答
【9353】Re:ユニークな数値を数えたい。 ichinose 03/11/30(日) 16:44 回答
【9429】Re:ユニークな数値を数えたい。自己レス ichinose 03/12/4(木) 7:58 発言
【9477】Re:ユニークな数値を数えたい。自己レス bykin 03/12/4(木) 21:01 回答
【9526】Re:ユニークな数値を数えたい。自己レス ichinose 03/12/7(日) 11:28 お礼
【9357】Re:ユニークな数値を数えたい。 りん 03/11/30(日) 17:54 回答

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