| 
    
     |  | こんばんは。 
 パッと見でおかしそうなところだけ。
 >Do whilehile i = C1
 ↓
 Do while i = C1
 綴り間違いです。
 
 >a = (*.pdf,application/pdf,PDF)
 aからhは検索する文字列ですよね?
 であれば、""で囲む必要があります。
 a = "(*.pdf,application/pdf,PDF)"
 
 >If Cells(i, 5, i, 7) = a Then
 このような書き方は出来ません。
 セルは1つずつ判定することになります。
 例えば、
 Dim j as Long
 Dim flg as Boolean
 For j = 5 to 7
 if cells(i,j).Value <> a then
 flg = True
 Exit For
 end if
 Next j
 If flg Then MsgBox a & " に一致しない文字列がありました。"
 
 >With Sheets("filechk").Cells(2, 5).CurrentRegion  '(2,5)をカレントにする
 >         右 = 3
 >         下 = Range(Cells(上, 左), Cells(上, 左)).End(xlDown).Row
 >End With
 よく意味が判りません。
 Withの意味がないようですが。。。
 
 >MsgBox "一致していない型がありました。色付セルを見直しましょう"
 エラーがなくてもメッセージが表示されることになります。
 先の例のように、エラーがあったらフラグを立てることによって、
 判定するなどの工夫が要ります。
 
 一気にaからhまでやろうとせずに、
 先ずは、1つの文字列に対しての判定を作ってみることをお薦めします。
 
 
 |  |