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

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

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

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

マクロ

定義された処理手続きに応じて、どのような一連の処理を行うのかを特定させるルールをマクロと呼びます。

Q&A

解決済

4回答

1066閲覧

VBA 複数セルの値を反映させたい

memem12

総合スコア12

VBA

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

マクロ

定義された処理手続きに応じて、どのような一連の処理を行うのかを特定させるルールをマクロと呼びます。

0グッド

0クリップ

投稿2021/01/18 07:33

入力された値が、下の図のように反映されるマクロを制作しているのですが、どのように書けばよいのか分かりません。

イメージ説明
符号、個数、番号の順番に入力していき、空だった番号のセルが入力されたときに
括弧つきで個数も反映されたいのです。

引数Targetを使った下のようなコードを考えているのですが、指定したセルと
隣の列セルを指定する方法がわからず詰まっています。
どのようにすればいいのか、アドバイスお願いします。
また、違う方法もあれば教えていただければ幸いです。

Private Sub Worksheet_SelectionChange(ByVal Target As Range)
On Error Resume Next
If Target.Column = 3 Then   'C列に入力すると作用

If Not Target <>"" Then     'セルが空ではない場合 Target.Value =( "(" &個数の値 & ")"& 入力した番号の値 ) Endif Else End If

End Sub

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

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

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

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

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

guest

回答4

0

皆様のお陰で自己解決できました。
ありがとうございました。

Private Sub Worksheet_Change(ByVal Target As Range)
Application.EnableEvents = False
If Target.Column = 3 And Target.Rows.Count <= 1 Then 'C列のセルを選び、1行目も含めたセルを選ぶ
If Target.Value <> "" Then '選んだセルが空ではない場合
Target.Value = "(" & Target.Offset(0, -1).Value & ")" & Target.Value
End If
End If
Application.EnableEvents = True
End Sub

投稿2021/01/19 01:25

memem12

総合スコア12

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

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

memem12

2021/01/19 03:15

頭から何行目は変えないなど、特定行を対象に外せないので未解決に戻しました。
退会済みユーザー

退会済みユーザー

2021/01/19 04:22

他人のコードをコピペして自己解決したという前にコードの意味を調べましょう
guest

0

なぜOn Error Resume Nextで誤魔化しているのか不思議でしたがエラー頻発で動きませんね。
バグをバグで修正すると終わらないので使わない方がいいです。
個人的には変換ボタンを準備して一括変換した方がエラー対応もしやすいのですが、逐一変換で作成しました。
offset操作はしていませんが、配列操作を覚える用で使ってください。

VBA

1'Worksheet_SelectionChange=選択範囲の変更時イベント 2Private Sub Worksheet_Change(ByVal Target As Range)v 3 '範囲選択エラー対応 4 If Target.Column = 3 And Target.Rows.Count <= 1 Then 5 '範囲選択エラー対応 6 If Target.Value <> "" Then 7   '必要なデータを配列取得 8 Dim List 9 List = Range(Cells(Target.Row, 1), Cells(Target.Row, 7)) 10 '配列内データで修正 11 List(1, 5) = List(1, 1) 12 List(1, 6) = List(1, 2) 13 List(1, 7) = ("(" & List(1, 2) & ")" & List(1, 3)) 14 '配列データで範囲上書き 15 Range(Cells(Target.Row, 1), Cells(Target.Row, UBound(List, 2))) = List 16 End If 17 End If 18End Sub

投稿2021/01/19 00:26

編集2021/01/19 00:36
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

0

これで如何でしょうか?

vba

1Private Sub Worksheet_Change(ByVal Target As Range) 2 Application.EnableEvents = False 3 4 If Intersect(Target, Columns("C")) Is Nothing Then 5 Exit Sub 6 ElseIf Target.Count > 1 Then 7 Application.EnableEvents = True 8 Exit Sub 9 ElseIf Target.Value = "" Then 10 Application.EnableEvents = True 11 Exit Sub 12 Else 13 Target.Value = "(" & Target.Offset(0, -1).Value & ")" & Target.Value 14 End If 15 16 Application.EnableEvents = True 17 18End Sub

投稿2021/01/18 11:09

Taka1108

総合スコア32

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

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

memem12

2021/01/19 00:12

コードありがとうございます。 このコードを基に空いたセルに書き込まれた時でも反映されるように書いてみます。
guest

0

ベストアンサー

入力値ならTarget.Value
単純に左をさすならTarget.Offset(, -1).Value
ですが、他にも色々問題はありそう。


vba

1Private Sub Worksheet_Change(ByVal Target As Range) 2Application.EnableEvents = False 3 4With Target 5If .Column = 3 And .Row > 1 And .Value <> "" Then 6 If InStr(.Value, "(") = 0 Then 7 .Value = "(" & .Offset(0, -1).Value & ")" & .Value 8 End If 9End If 10End With 11 12Application.EnableEvents = True 13End Sub

投稿2021/01/18 08:24

編集2021/01/19 03:59
radames1000

総合スコア1925

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問