Softex CelwareTech Blog
Excel VBA2026-05-27

セルの値を増減させるExcel VBA汎用プロシージャ ChangeValueCell

指定セルの値を任意ステップで増減し、任意で最大値・最小値も指定できるExcel VBA汎用プロシージャを解説します。

Excel VBA汎用プロシージャRange数値入力入力補助

概要

ChangeValueCellは、指定したセルの値を増加または減少させる汎用プロシージャです。増減幅Step、増加か減少かを表すUp_True、任意の最大値・最小値を指定できます。

図形ボタンで選択セルの値を増減する処理では、選択セルの値を1ずつ上下させるために使っています。

使う場面

  • セルの数値をボタン操作で増減したい
  • 数量や人数などを1ずつ変更したい
  • 上限・下限つきの数値変更を共通化したい
  • 増加処理と減少処理を1つのプロシージャで扱いたい

使用例

' A1を1増やす
Call ChangeValueCell(Range("A1"), 1, True)

' A1を1減らす
Call ChangeValueCell(Range("A1"), 1, False)

' 0から10の範囲で1増やす
Call ChangeValueCell(Range("A1"), 1, True, 10, 0)

コピー可能な実装コード

ChangeValueCell.bas
vba
コードを読み込み中...

初心者向けコード解説

Targetは値を変更したいセルです。Stepは増減幅で、Up_TrueTrueなら増加、Falseなら減少します。

MaxValueMinValueは省略可能です。元コードでは-9999を「指定なし」の目印として使っています。最大値が指定されている場合は、それを超えないときだけ値を変更します。最小値が指定されている場合も同様です。

Target(1).Valueで対象範囲の先頭セルの値を読み取っています。単一セルを渡す想定です。複数セルを渡すと、先頭セルの値を基準に計算した結果が対象範囲全体へ代入されるため、通常は単一セルを渡します。

関連記事

注意点

  • 対象セルには数値が入っている前提です。
  • 複数セル範囲を渡すと、範囲全体が同じ値に更新されます。
  • -9999を実際の上限・下限として使いたい場合は、未指定判定の値を変える必要があります。
  • 空欄や文字列を扱う場合は、IsNumericなどの判定を追加すると安全です。

軽いまとめ

ChangeValueCellは、セルの数値変更を共通化する小さな部品です。ボタンUI、キーボード操作、入力補助マクロなどから呼び出せるため、Excelツールの操作性改善に使いやすいプロシージャです。

この技術で業務改善しませんか?

Excel VBA・GAS・Webアプリで業務の自動化ツールを開発しています。 「こんなことできる?」というご相談だけでもお気軽にどうぞ。

無料相談はこちら →