ここから本文です

列にFalseと値が出た時の条件式を作りたいのですが。

par********さん

2013/11/2510:56:12

列にFalseと値が出た時の条件式を作りたいのですが。

今、正誤表を作っていて、ざっくり処理の順番は以下のようになってます。
1) データをAシート、Bシートに対し各方面からデータを吸い上げ(マクロで実施)
2) データ判定(C列にTrueかFalseが表示)
3) ファイルを保存して閉じる

ここまでは今まで実施していたのですが、3)の箇所を修正して2)の判定でC列が”False”の値だった場合、ファイルを閉じないとしたいのです。列の中に1つでもFalseがあった場合の判定を作ったことが無いのでどうすればいいかわかりません、詳しいかた、アドバイスお願いいたします。

補足以下のようなVBAを作って、ファイルシート上のパスのファイルを開き、そのファイルのマクロを実行した後、その実行ファイルのシートのC列で”False”が出る出ないで今回の式を設定したいのですが、やはりFalseの判定が出てもファイルが閉じられてしまいます。F8で実施してみてもどこが間違っているかわかりません。ちょっと丸投げ気味になってしまいますがわかる方、お願いいたします~。(実行ファイルの「マクロ」は実行後、ファイルは対象シートを展開のままになります。)

If Dir(FilePath) <> "" Then 'ファイルが存在すれば開く
Workbooks.Open FilePath
Workbooks(FileName(i)).Worksheets(1).Activate
Application.Run "'" & FilePath & "'!マクロ"

If Application.CountIf(Columns("E:E"), False) > 0 Then
Workbooks(FileName(i)).SaveAs

ElseIf Application.CountIf(Columns("C:C"), False) = 0 Then
Workbooks(FileName(i)).Close SaveChanges:=True
End If
Else
MsgBox FilePath & "が存在しません"

閲覧数:
196
回答数:
1
お礼:
50枚

違反報告

ベストアンサーに選ばれた回答

msk********さん

編集あり2013/11/2814:32:45

一例です。
If Application.Countif(Columns(列),False) > 0 Then
'ファイルクローズ
End If

因みにFalseが文字列の場合は二重引用符で囲って下さい。

補足から
このマクロが標準モジュールなら問題ないと思いますが、シートモジュールならColumnsのシートオブジェクトが相違しますのでこんな感じです。


With Workbooks(FileName(i)).Worksheets(1) '追加
.Activate '変更
Application.Run "'" & FilePath & "'!マクロ"
If Application.CountIf(.Columns("E:E"), False) > 0 Then '変更
Workbooks(FileName(i)).SaveAs
ElseIf Application.CountIf(.Columns("C:C"), False) = 0 Then '変更
Workbooks(FileName(i)).Close SaveChanges:=True
End If
End With '追加

みんなで作る知恵袋 悩みや疑問、なんでも気軽にきいちゃおう!

Q&Aをキーワードで検索:

Yahoo! JAPANは、回答に記載された内容の信ぴょう性、正確性を保証しておりません。
お客様自身の責任と判断で、ご利用ください。
本文はここまでです このページの先頭へ

「追加する」ボタンを押してください。

閉じる

※知恵コレクションに追加された質問は選択されたID/ニックネームのMy知恵袋で確認できます。

不適切な投稿でないことを報告しました。

閉じる