下記のように B列に数字が縦に並んでいます。
28.11684736
28.12102177
28.12519803
28.12937616
28.13355614
28.13773798
28.14192168
28.14610723
28.15029464
28.15448391
28.15867503
28.16286801
28.16706285
28.17125955
28.1754581
この数字群から、例えば 28.15448391 に一致する数字の行を見つけて
その行番号を抽出するコードはどのように記述したらよいのでしょうか。
番号はA1のセルに置きます。
但し、条件があって
Excel2000~Excel2003の全てのバージョンに共通する
こと。そして列のデータ数が約10000程度はあることです。どこから
手をつけてよいのか判らないので、よろしくお願いします。
簡単な例では下記でもよさそうですが。より早く求めるには???
A= Range("B65536").End(xlUp).Row
I=0
Do
I=I+1
Loop until Cells(I,2).value=28.15448391
Range("A1")=I
No.2ベストアンサー
- 回答日時:
こんにちは。
そのような内容は、別に、VBAでなくても良さそうですが。
=IF(ISERROR(MATCH(A1,B:B,0)),"Not Found",MATCH(A1,B:B,0))
VBAなら、そのまま移植すればよいと思います。
以下は、Excel 97 ~ 2007 まで動作可能です。
ただし、見つけるデータは一つという条件下です。
'標準モジュール
Sub Test1()
Dim ret As Variant
Dim mDat As Variant
mDat = Range("A1").Value
If VarType(mDat) <> vbDouble Then Exit Sub
ret = Application.Match(mDat, Columns(2), 0)
If Not IsError(ret) Then
MsgBox ret & "行目に見つかりました。", vbInformation
Else
MsgBox mDat & "は、見つかりません。", vbCritical
End If
End Sub
No.3
- 回答日時:
VBAは、解らないので
関数で
同じ数値が1つだけでB2から数値が入力されている場合
A1に =IF(ISERROR(MATCH(28.15448391,B2:B100,0)),"0",MATCH(28.15448391,B2:B100,0)+ROW(B2)-1)
No.1
- 回答日時:
B列が昇順であることが条件です
Application.ScreenUpdating = False
A = Range("B65536").End(xlUp).Row
Cells(1, 1).Formula = "=match(" & B & ",B1:B" & A & ")"
If Cells(Cells(1, 1).Value, 2) = B Then
Cells(1, 1).Value = Cells(1, 1).Value
Else
Cells(1, 1).Value = "見つかりません"
End If
Application.ScreenUpdating = True
☆当方VBAは苦手なので参考まで
ありがとうございました。
Cells(1, 1).Formula = "=match(" & B & ",B1:B" & A & ")"
新鮮でした。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・14歳の自分に衝撃の事実を告げてください
- ・架空の映画のネタバレレビュー
- ・「お昼の放送」の思い出
- ・昨日見た夢を教えて下さい
- ・ちょっと先の未来クイズ第4問
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・メモのコツを教えてください!
- ・CDの保有枚数を教えてください
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・ハマっている「お菓子」を教えて!
- ・最近、いつ泣きましたか?
- ・夏が終わったと感じる瞬間って、どんな時?
- ・10秒目をつむったら…
- ・人生のプチ美学を教えてください!!
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Excel2017 フィルタ昇順並びがA...
-
急ぎ!色のついたセルを非表示...
-
エクセルで行の高さ及び列幅の...
-
オートフィルタ後のデータから...
-
エクセルの時刻のカウントが出...
-
プルダウンに【なし、平均、デ...
-
Excelで並び替え後にア行...
-
基準日以前のデータを範囲を指...
-
特定の行を選択して別のシート...
-
EXCELで日付を比べ3か月以内の...
-
excel / ピポッド 日数を出したい
-
Excelで複数列のデータを1列に...
-
EXCEL 最終行のデータを他のセ...
-
列と行の名前(重複あり)が交...
-
エクセル関数について
-
時間の重複チェック
-
Excelで、空白を表示したい
-
エクセルで円グラフに引き出し...
-
エクセルで文字を含む式に、カ...
-
エクセルの主軸と第2軸の0を合...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Excel2017 フィルタ昇順並びがA...
-
エクセルで行の高さ及び列幅の...
-
Excelで並び替え後にア行...
-
オートフィルタ後のデータから...
-
基準日以前のデータを範囲を指...
-
急ぎ!色のついたセルを非表示...
-
エクセルの時刻のカウントが出...
-
文字列を比較し、相違するフォ...
-
【Excel VBA】指定した行の最大...
-
プルダウンに【なし、平均、デ...
-
エクセル VBA 行間隔を飛ばした...
-
時間の重複チェック
-
エクセル関数について
-
マクロで行の高さを設定したい
-
EXCELで日付を比べ3か月以内の...
-
エクセル 複数行ある同一商品...
-
excel / ピポッド 日数を出したい
-
複数回答のクロス集計の方法
-
検索条件に合うセルの個数を数...
-
エクセル関数のSUMPRODUCTにつ...
おすすめ情報