中身はとても簡易的なもので,あるセルの文字列に対して対象の文字列が部分一致していれば抽出するというものなのですが,どうもプロシージャ名の部分で,"変数が定義されていません"と出てしまいます。恐らく初歩的なことだとは思いますが全く気づけないのでわかる方は教えて頂けると助かります。
コードは下記です。
Option Explicit
Sub test()
Dim myRange As Range
Dim myObj As Range
Dim keyWord As String
Dim i, j As Integer
Set myRange = Range("B:B")
i = 2
j = 2
Do While i <= 100
keyWord = Cells(A, i)
Set myObj = myRange.Find(keyWord, LookAt:=xlPart)
If myObj Is Nothing Then
i = i + 1
Else
Cells(C, j) = myObj
j = j + 1
End If
Loop
End Sub
No.4ベストアンサー
- 回答日時:
A列の11文字がB列にあるか?
ということなら。
Option Explicit
Sub test()
Dim myRange As Range
Dim myObj As Range
Dim fstRange As Range
Dim keyWord As String
Dim i As Long, j As Long, iMax As Long
Set myRange = Range("B:B")
i = 2
j = 2
iMax = Cells(Rows.Count, "A").End(xlUp).Row
Do While i <= iMax
keyWord = Left(Cells(i, "A").Value, 11)
If myObj Is Nothing Then
Set myObj = myRange.Find(keyWord, LookAt:=xlPart)
Set fstRange = myObj
Else
Set myObj = myRange.Find(keyWord, myObj, LookAt:=xlPart)
If myObj.Row = fstRange.Row Then Set myObj = Nothing
End If
If myObj Is Nothing Then
i = i + 1
Else
Cells(j, "C").Value = myObj.Value
j = j + 1
End If
Loop
End Sub
No.3
- 回答日時:
こんにちは
>どうもプロシージャ名の部分で,"変数が定義されていません"と出てしまいます。
全体の構文チェックに引っかかる場合、プロシージャ名の部分が反転します。
ですので、必ずしもその行でエラーが発生しているわけではありません。
実際の原因は(既に指摘がでていますが)
>Cells(A, i)
>Cells(C, j)
の部分で、「A」、「C」は変数とみなされます。
(i、j と同様ですね)
>Option Explicit
の宣言があるのに対して、変数A、Cの宣言がされていないので、「変数が定義されていません」というエラーメッセージになっているものと考えられます。
もしも列番号を指定したいのなら、1、3 とするか、"A"、"C"とするかですが、Cellsの場合の引数は(行番号、列番号)の順と決まっているので、
Cells(i, 1)
または
Cells(i, "A")
などとしておく必要があります。
あるいは、A1形式の方がお馴染みであるのなら、
Range("A" & i)
のような記述にしておくかでしょうか。
No.2
- 回答日時:
こんなことがしたいのかな?
Option Explicit
Sub test()
Dim myRange As Range
Dim myObj As Range
Dim fstRange As Range
Dim keyWord As String
Dim i As Long, j As Long, iMax As Long
Set myRange = Range("B:B")
i = 2
j = 2
iMax = Cells(Rows.Count, "A").End(xlUp).Row
Do While i <= iMax
keyWord = Cells(i, "A").Value
If myObj Is Nothing Then
Set myObj = myRange.Find(keyWord, LookAt:=xlPart)
Set fstRange = myObj
Else
Set myObj = myRange.Find(keyWord, myObj, LookAt:=xlPart)
If myObj.Row = fstRange.Row Then Set myObj = Nothing
End If
If myObj Is Nothing Then
i = i + 1
Else
Cells(j, "C").Value = myObj.Value
j = j + 1
End If
Loop
End Sub
ご丁寧な回答ありがとうございます。
恐らくそのような認識で間違いないと思うのですがどうもうまく動いてくれず…。
A列に例えば日時のような220219-142230のような文字列があり,B列にも同じような文字列がある状態で,日付と分単位まで一致しており,秒単位は問わずに分単位までで一致したもの(要するにそこまでの文字列が重複したもの)をC列に並べていきたいといった内容になっております。
この前提の場合だと現在の書き方では難しいのでしょうか…??
No.1
- 回答日時:
こんにちは。
デバッグのコンパイルをされれば、どこでエラーが出るかが分かるかと。
https://www.excelspeedup.com/vbadebug/
下記の2か所が原因になりますね。
誤り 正しくは
Cells(A, i) → Cells("A", i) 又は、Cells(1, i)
Cells(C, j) → Cells("C", j) 又は、Cells(3, j)
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
- ・ゆるやかでぃべーと タイムマシンを破壊すべきか。
- ・歩いた自慢大会
- ・許せない心理テスト
- ・字面がカッコいい英単語
- ・これ何て呼びますか Part2
- ・人生で一番思い出に残ってる靴
- ・ゆるやかでぃべーと すべての高校生はアルバイトをするべきだ。
- ・初めて自分の家と他人の家が違う、と意識した時
- ・単二電池
- ・チョコミントアイス
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
End Sub が必要です。
-
対応する関数ヘッダーがありません
-
(fortran) run-time erro M620...
-
C# IEnumerable が IEnumerable...
-
プロポからのパルス値解析ソー...
-
C++のことで・・教えてください。
-
フォートランのエラーについて...
-
intel fortranのエラーで困って...
-
python numpy.linalg.inv()での...
-
Excel VABについて 下記記述が...
-
C言語コンパイルエラー cygwin
-
verilogでデマルチプレクサの作...
-
教えて下さい
-
特定のPCだけ動作しないVBAマク...
-
エクセルで特定の列が0表示の場...
-
UserForm1.Showでエラーになり...
-
Excel・Word リサーチ機能を無...
-
Excel マクロ VBA プロシー...
-
配列数式の解除
-
String""から型'Double'への変...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
End Sub が必要です。
-
フォートランのエラーについて...
-
43:syntax error at end of input
-
intel fortranのエラーで困って...
-
C# IEnumerable が IEnumerable...
-
他クラスからForm1内コントロル...
-
Delphiでif文がうまく書けないです
-
C2065: 'EnumDisplayDevices' :...
-
DLL内からの外部変数の参照
-
構造体のポインタ参照
-
pythonの条件分岐(if)
-
ラズパイ上の、pythonのエラー...
-
Excel VABについて 下記記述が...
-
フォートラン(fortran)のエラー...
-
Excel VBA: UserForm.Show で実...
-
#ifndefとかヘッダファイルにつ...
-
DLLの使い方とerror C2146につ...
-
C言語コンパイルエラー cygwin
-
Makefile と <math.h>
-
python numpy.linalg.inv()での...
おすすめ情報