質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.31%
VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

Q&A

解決済

1回答

1814閲覧

VBA自作関数にて現在のセル

AMK

総合スコア765

VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

0グッド

0クリップ

投稿2022/06/09 08:55

編集2022/06/10 08:09

やりたいこと

ユーザー定義関数を使用して、現在の位置を取得してC4セル(Offsetで-3)の値を取得したい。
イメージ説明

調べたこと

【ユーザー定義 関数 VBA セル位置】
上記キーワードにてグーグル先生に聞く。

参考にしたサイト

参考サイトのコード単体では問題なくセルを表示された。

現状のコードに組み込むとセルを取得する部分でエラーになる
イメージ説明

セル取得コード単体では怒られないので
oil_sum(MyFunction())
上記のように2つに関数を分けてみたが循環のエラーで怒られる。

VBA

1Function oil_sum() 2 '変数 3 Dim element As Integer 4 Dim color As Integer 5 Dim oil As Integer 6 7 myAddress = Application.ThisCell.Address 8 '0はFalseでも同じ。0が無いと絶対表 9 'エレメント判定 10 If Range(myAddress).Offset(-1, 0).Text = "" Then 11 '空白なのでエレメント交換無し 12 element = 0 13 14 Else 15 '文字入力されているのでエレメント交換有り 16 element = Val(Range(myAddress).Offset(-3, 0).Value) 17 End If 18 '合計 19 Range(myAddress).Value = CStr(element + oil) 20End Function

自分なりには出来るところまでやったのですが、手詰まりなので
ご教示お願い致します。

追記

取得できないのであれば、セルに手入力で自分のセルを入力してみようと思いやってみた結果
循環のエラーが発生しました。
イメージ説明

メッセージボックスが常に3回開いてしまう現象
Range(myAddress)が3つあるので、ココを疑ってみることにして
Withステートメントを使ってみたが、3回メッセージボックスが表示された
イメージ説明

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

Function oil_sum() '変数 Dim element As Integer Dim oil As Integer With Application.ThisCell oil = .Offset(-2).Value element = IIf(.Offset(-1).Value = "", 0, .Offset(-3).Value) End With oil_sum = oil + element End Function

投稿2022/06/09 09:53

編集2022/06/09 10:03
jinoji

総合スコア4592

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

AMK

2022/06/10 07:43

回答ありがとうございます! 早速試してみたのですが、コードをコピペして使ってみても動作しませんでした
AMK

2022/06/10 07:52

エラーは、With Application.ThisCell の部分でエラーになり止まりました
jinoji

2022/06/10 08:23

C7セルに =oil_sum() と入力してEnterした結果ですか?
AMK

2022/06/10 14:30

はい エンター押してもエラーのままでした
AMK

2022/06/11 06:20

スミマセン、コピペしたときに関数名変えていて 出力時の変数名を変更していませんでした。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.31%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問