ここから本文です

Vbaにて Dim MaxRow As String MaxRow = CStr(Cells(Rows.Count, 1).End(xlUp).R...

uma********さん

2016/7/2716:55:41

Vbaにて
Dim MaxRow As String
MaxRow = CStr(Cells(Rows.Count, 1).End(xlUp).Row)
Dim initial As String


Cells(4, 128) = "稼働時外気温度"
initial = "S"
MaxRow = initial +

MaxRow
Cells(4, 129).Formula = "=AVERAGEIFS(S3:MaxRow,S3:MaxRow,"">0"")"

このようなコードをかいたのですが、出力セルには#NAME$がでてしまいます。どのようにすればちゃんと出力されますか?

閲覧数:
71
回答数:
1
お礼:
25枚

違反報告

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

kyo********さん

2016/7/2717:11:57

DY4に入った関数を見ましたか?
=AVERAGEIFS(S3:MaxRow,S3:MaxRow,">0")
最低でも
Cells(4, 129).Formula = "=AVERAGEIFS(S3:" & MaxRow & ",S3:" & MaxRow & ","">0"")"
と変数は""の外に書くべきでしょう。
それと
Dim MaxRow As long
MaxRow = Cells(Rows.Count, 1).End(xlUp).Row
として、
Cells(4, 129).Formula = "=AVERAGEIFS(S3:S" & MaxRow & ",S3:S" & MaxRow & ","">0"")"
とinitial部分は省略、式に組み込んでしまってもよろしいのでは。

F8キーでステップ実行しながら格納されている変数をマウスオンで確認してみてください。

この質問につけられたタグ

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

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

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

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

閉じる

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

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

閉じる