![](http://oshiete.xgoo.jp/images/v2/pc/qa/question_title.png?e8efa67)
マクロ初心者です。
エクセルで出納帳を作っています。
必要に応じて行を追加挿入する為に、ボタンを作成しそこからアクティブセルのある行の次の行に
行を追加し計算式をコピーするマクロを入れてあります。
(ネットで見つけたコードを参考にしています。)
一行挿入して数式をコピーさせるコードは下記のとおりです。
(挿入ボタンクリック、確認してから行が挿入するようになっています)
列はA列からP列まで使用、
A、B、C、D、H、K、M、N、O、Pの各列に計算式が入っており、挿入した行の各列の数式をコピーさせています。
ちなみに、Eはドロップダウンリストから選択、F、G、I、J列は手入力で必要なデータ等を入力しています。
アクティブセルがある行はセル色が緑になるようになっております。
画像が小さくて見づらいかもしれません。
申し訳ありません。
Sub 追加確認()
If MsgBox("実行してよろしいですか?", vbOKCancel) = vbOK Then
insert_click
End If
End Sub
Sub insert_click()
Sub insert_click()
Application.ScreenUpdating = False
ThisWorkbook.ActiveSheet.Unprotect Password:="0000"
Dim wgyou As Long
wgyou = ActiveCell.Row
If wgyou < 2 Then Exit Sub
Application.CutCopyMode = False
Range(wgyou + 1 & ":" & wgyou + 1).Select
Selection.EntireRow.Insert
Range("A" & wgyou & ":D" & wgyou).Copy
Range("A" & wgyou + 1 & ":D" & wgyou + 1).PasteSpecial Paste:=xlPasteFormulas
Range("H" & wgyou).Copy
Range("H" & wgyou + 1).PasteSpecial Paste:=xlPasteFormulas
Range("K" & wgyou & ":P" & wgyou).Copy
Range("K" & wgyou + 1 & ":P" & wgyou + 1).PasteSpecial Paste:=xlPasteFormulas
Application.CutCopyMode = False
Range("A" & wgyou + 1).Select
ThisWorkbook.ActiveSheet.Protect Password:="0000"
Application.ScreenUpdating = True
End Sub
複数行追加する場合、時間も掛かり一行ずつ追加するのに不便が生じている為
「行挿入ボタン」⇒「挿入の確認」⇒「挿入する行数の指定」⇒「指定した行数を挿入しアクティブセルのある行の数式を挿入した行数分コピーさせる」
ができるコードに変更したいと思っています。
複数行挿入するコードもネットを参照して入れてみましたが
いくら調べても複数行挿入と計算式をコピーさせることができません。
重複しますが、上記のコードを指定した行数分行行を挿入し、数式をコピーさせるように変更させたく思います。
分かりづらい説明で大変申し訳ありませんが、
何卒お力添えいただけますようよろしくお願いいたします。
![「エクセルのVBAで指定した行数の追加と数」の質問画像](http://oshiete.xgoo.jp/_/bucket/oshietegoo/images/media/d/542288939_569515895611a/M.png)
A 回答 (2件)
- 最新から表示
- 回答順に表示
No.2
- 回答日時:
ご質問文でよくわからないところがありますが・・・
とりあえずこんな感じでしょうか?
(変更というよりは別の形ですが…)
Sub TEST()
Dim str As String, v As Long
Dim rng As Range, c As Range
Set c = ActiveCell
str = InputBox("挿入行数を入力してください", "行の追加", "1")
If c.Row > 1 And IsNumeric(str) Then
v = Int(Val(str))
If v > 0 Then
ActiveSheet.Unprotect Password:="0000"
Set rng = c.Offset(1, 0).Resize(v, 1).EntireRow
c.EntireRow.Copy
rng.Insert
rng.Offset(-v, 0).SpecialCells(xlCellTypeConstants).ClearContents
c.Select
ActiveSheet.Protect Password:="0000"
End If
End If
End Sub
※ ご提示のコードの変更で実現なさりたい場合は、ご提示の内容を指定行数分繰り返すようにすればよろしいかと思います。
繰り返しは、例えば For ~~ Next などで実現できます。
fujillinさん
分かりづらい質問ですみません。
まさにやりたいと思っていた通りにできました!
アドバイスいただいたFor~~Nextでもできるよう色々勉強してみます。
有難うございました!
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) VBAで重複した値のセルに色付けをしたい 1 2022/11/02 16:12
- Visual Basic(VBA) 3つのプロシージャをまとめたら実行時エラー発生で対応不能 6 2022/05/17 01:47
- Excel(エクセル) エクセルのマクロについて教えてください。 3 2023/02/07 14:47
- Excel(エクセル) 2つのVBAを一緒にしたら機能しなくなりました(エクセル) 7 2022/06/02 12:41
- Excel(エクセル) 列の最終行に新たに入力されたらその値を自動参照 1 2023/01/21 09:59
- Visual Basic(VBA) 【VBA】Excelで罫線を引きたい 3 2022/07/14 12:04
- Visual Basic(VBA) excel2021で実行できないマクロ。どこを直したらいいのか 2 2022/03/28 03:40
- Visual Basic(VBA) 【前回の続き続きです、ご教示ください】VBAの記述方法がわかりません。 2 2022/08/24 20:49
- Excel(エクセル) 表示形式、文字列セル(列)に数式を入力するには マクロ 1 2022/09/18 10:53
- Visual Basic(VBA) [Excel VBA] このコードでは行の挿入や行の消去をすると13のエラーが出てしまう。 3 2022/12/09 00:29
このQ&Aを見た人はこんなQ&Aも見ています
-
「どうして捨てられないの?」前妻の物を捨てられない男性の心理って?
前妻の物を捨てられない理由に加え、捨てるための手段はあるのかを専門家に聞いてみた!
-
Excel VBA 複数行を数の分だけ挿入したい
Visual Basic(VBA)
-
Excelで、あるセルの値に応じて行を自動挿入したい
Visual Basic(VBA)
-
エクセルで表示された値だけ行数をコピーし挿入、挿入行の指定したセルに連続した値を表示できますか?
Excel(エクセル)
-
-
4
Excel で行を指定回数だけコピーしたい
Excel(エクセル)
-
5
マクロ 行挿入で数式も反映する方法
Excel(エクセル)
-
6
【エクセル】行挿入で数式もいっしょにコピーしたい
Excel(エクセル)
-
7
excelで任意のセルを指定回数コピーペーストする方法を教えてください
Excel(エクセル)
-
8
エクセルでセルの値分の個数の文字列を自動で入れたい
Excel(エクセル)
-
9
エクセルVBAで、行コピーを複数行にペーストする方法
Excel(エクセル)
-
10
VBAで条件が一致する行をコピーしその1つ下へ挿入
Excel(エクセル)
-
11
特定の文字を条件に行挿入とそこからセルデータを追加するVBAについて
Visual Basic(VBA)
-
12
特定の条件の時に行を挿入したい
Excel(エクセル)
-
13
E列のセルに数値が入れば(空白でなければ)B列の同じ行のセルに色がつく
その他(Microsoft Office)
-
14
VBAで行コピーして挿入
Visual Basic(VBA)
-
15
VBAで繰り返しコピーしながら下へ移動させる方法
Excel(エクセル)
-
16
【VBA】特定の値が入った行をコピーして別シートに貼り付ける方法をおしえていただきたいです。
Excel(エクセル)
-
17
【VBA】2つのシートの値を比較して条件一致したら、同じ行の隣の値を別ブックへ転記したいです。 VB
Visual Basic(VBA)
-
18
毎回変わる範囲を検索し、コピペするマクロについてご教示ください。
Excel(エクセル)
-
19
エクセルのエラーメッセージ「400」って?
Visual Basic(VBA)
-
20
エクセル。行を挿入すると、関数が反映されない
Windows 10
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Excel VBAでオートフィルタで抽...
-
列から特定の文字列検索→該当以...
-
エクセルで階層図を作る方法
-
【VBA】条件に一致しない行を削...
-
VBAで保存しないで閉じると空の...
-
WPSOffice_マクロの有効化について
-
エクセル関数>参照ファイル名...
-
Excel マクロの編集がグレーに...
-
エクセル ボタンに設定したマク...
-
エクセルのvbaにて thisworkboo...
-
(Excel VBA)シートコピー時マ...
-
Ctrl+Zが使えない
-
マクロをマクロを使ってコピー...
-
エクセルで、「いいね」のよう...
-
エクセルの、記録を終了したマ...
-
LDPlayerのマクロの編集方法を...
-
エクセルの表を複数枚印刷した...
-
エクセル:マクロの保存先(I...
-
複数のExcelブックから特定シー...
-
リーグ戦(10チーム2コート)作...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
数値に見えるものはすべて数値...
-
マクロで最終行を取得してコピ...
-
【VBA】条件に一致しない行を削...
-
エクセルで空白行を削除する ...
-
エクセルのデータがない行には...
-
【VBA】条件に一致しない行を削...
-
VB.net
-
Excel VBAでオートフィルタで抽...
-
列から特定の文字列検索→該当以...
-
Excel97 指定した行だけマク...
-
エクセルで階層図を作る方法
-
Excel 別ブックから該当データ...
-
VBAでの重複データに色付け
-
EXCEL VBAでA列にある空白行よ...
-
マクロにて指定の文字間の文字...
-
エクセルのVBAで指定した行数の...
-
Access2003レポート:最終ペー...
-
VBAで特定の行と一つ上の行を削...
-
各個体に対する平均値の自動計...
-
Excel マクロ 検索結果を別シ...
おすすめ情報