
こんにちは。
VBAの最大値の求め方の質問です。
期待利益3、4.5、3.5の順番で範囲cells(30~32,''G'')の中から最大値を求めなくてはいけなくて、求めた最大値をcells(33,''G'')に入れたいです。
Dim maxx as integer,x as integer
maxx = 0
For x = 1 To 3
If maxx < Cells(30, "G") Then 'これが3.0
maxx = Cells(30, "G")
ElseIf maxx < Cells(31, "G") Then 'これが4.5
maxx = Cells(31, "G")
Else 'これが3.5
maxx = Cells(32, "G")
End If
Cells(33, "G") = maxx
Next x
最初にある
maxx = 0
For x = 1 To 3
If maxx < Cells(30, "G") Then
maxx = Cells(30, "G")
この部分で既にmaxxが0より大きいのでelseif以降が機能しないのは分かっています。
どう書き直せば3つの数字の中から比較できるか知りたいです。
よろしくお願いします。

A 回答 (4件)
- 最新から表示
- 回答順に表示
No.4
- 回答日時:
単純に最大値を求めるだけですか?
関数使わなければ、
1.一つ目をMAXに代入
2.IF MAX<二つ目なら二つ目をMAXに代入
3.IF MAX<三つ目なら三つ目をMAXに代入だけでいいのでは?
ELSE要りません。
FOR NEXTも要らないですね。
No.3
- 回答日時:
以下のようにしてください。
①最初にmmaxに0をいれてあります。
②30行から32行まで、以下を繰り返します。
G列の期待利益がmmaxより大きいならその値をmmaxに設定します。
③結果的にmmaxに最も大きい値が設定されます。
それを33行目のG列に設定します。
尚、mmaxの型をintegerにすると-32768~32767の整数しか扱えません。
小数点以下も扱いたいならVariant型かDouble型にすべきです。
xの型はintegerでも構いませんが、扱える範囲がせまいです。Long型を使用すると約10桁の整数まで扱えるので、Long型を使用したほうが便利です。
PCにメモリが少なかった大昔は、メモリの節約のためにinteger型を使用していましたが、今はその必要はありません。
-----------------------------------------------
Dim maxx As Variant
Dim x As Long
maxx = 0
For x = 30 To 32
If maxx < Cells(x, "G") Then
maxx = Cells(x, "G")
End If
Next x
Cells(33, "G") = maxx
No.1
- 回答日時:
手書きなので違うかも?
maxx = worksheetfunction.max(Cells(30, "G") ,Cells(31, "G") ,Cells(32, "G"))
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) VBAで組み合わせ算出やCOUNTIFSの処理を高速化したいです。 4 2022/04/07 02:38
- Visual Basic(VBA) vbaの計算 if elseと範囲について 6 2022/11/26 01:49
- Visual Basic(VBA) VBA 請求書自動作成 3 2022/04/24 01:58
- Excel(エクセル) VBAの指示の内容 昨日こちらでご教示頂いたのですが初心者な為、一つ一つの指示が何をやっているのかわ 2 2022/10/25 18:08
- Visual Basic(VBA) VBA Userformで一部別シートに転記がしたいのですが 2 2023/05/24 13:08
- Visual Basic(VBA) いつもお世話になっております、VBAで教えて頂きたいのですが 2 2022/05/05 22:20
- Visual Basic(VBA) vba 重複データ合算 5 2023/07/05 18:55
- Visual Basic(VBA) 実行時エラー´5854´ 文字列型パラメーターが長すぎます。 3 2023/06/08 21:17
- Excel(エクセル) エクセルVBAでオブジェクトが必要です 2 2022/09/10 16:37
- Visual Basic(VBA) 数字が「0」の列を削除するため、下記のコードを実行しましたが、コンパイルエラーSubまたはFunct 3 2022/12/04 00:00
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
EXCEL/VBA 変数の値をクリップ...
-
VB6.0 DataGridでのfirstRowの...
-
VBAでダブルコーテーション入り...
-
gridViewの行選択解除
-
エラーの意味は? Lvalue req...
-
stdpicture型の変数に、、
-
テキストボックスの値を変数に...
-
ビット否定(反転)の記号はど...
-
足して100になるような乱数のア...
-
Excel-vba 文字列と変数を...
-
Cプログラムについて
-
C言語(DXlib)での音ゲーについ...
-
Windows11のカメラで動画を撮り...
-
クッキーCookieで、値のサイズ...
-
excelの、ある数式内の{}の意...
-
BNF(バッカス・ナウア・記法)
-
初心者プログラミング
-
c言語の文字列について質問です...
-
CGIのPerlの変数をJavaScrip...
-
Ruby 文字コード判別
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
VBAでダブルコーテーション入り...
-
エラーの意味は? Lvalue req...
-
EXCEL/VBA 変数の値をクリップ...
-
jsp~jspにhiddenを使って変数...
-
整数xxxが大き過ぎますというエ...
-
C言語 アロー演算子について質...
-
[VBS]変数を定数に変換する方法...
-
Variant型で宣言してるのにEmpt...
-
テキストボックスの値を変数に...
-
processing エラーで、 "cannot...
-
Accessコンボボックスにレコー...
-
DataTableの値を変数に代入したい
-
条件演算子 ? :
-
インクリメント演算子の前置(+...
-
プログラミングで変数と関数の...
-
gridViewの行選択解除
-
無名関数のメリットがよくわか...
-
stdpicture型の変数に、、
-
論理演算子について
-
COBOLの変数
おすすめ情報