質問編集履歴
2
タイトル変更
title
CHANGED
@@ -1,1 +1,1 @@
|
|
1
|
-
あるExcelの複数のシートから、特定の値を持つ「行」のみ別のExcelへ抽出したい
|
1
|
+
【内容追記】あるExcelの複数のシートから、特定の値を持つ「行」のみ別のExcelへ抽出したい
|
body
CHANGED
File without changes
|
1
途中経過
title
CHANGED
File without changes
|
body
CHANGED
@@ -19,4 +19,47 @@
|
|
19
19
|
その契約で得られる仲介手数料等が算出される形となります。
|
20
20
|
|
21
21
|
|
22
|
-
私の勉強不足によりおかしな質問をしているかもしれませんが、何卒よろしくお願いいたします。
|
22
|
+
私の勉強不足によりおかしな質問をしているかもしれませんが、何卒よろしくお願いいたします。
|
23
|
+
|
24
|
+
###途中経過
|
25
|
+
ご回答いただいた方々のおかげで、元シートをコピー後、別ブックへの書き込みは
|
26
|
+
できるようになりました。
|
27
|
+
ただ、複数行が対象となった場合に、貼付けの動作が1行の中でループしてしまいます。
|
28
|
+
(言葉で伝わるか微妙なところですが)
|
29
|
+
|
30
|
+
98%回答いただいたコードですが以下のコードです。
|
31
|
+
【やりたいこと】
|
32
|
+
対象となった行を別ブックに貼付け、次の対象となった行はその下に貼付ける 以後繰り返し
|
33
|
+
```ここに言語を入力
|
34
|
+
Sub 書きかけ()
|
35
|
+
|
36
|
+
|
37
|
+
Dim i As Integer
|
38
|
+
i = 1
|
39
|
+
|
40
|
+
Dim sht As Worksheet
|
41
|
+
Dim rng As Range
|
42
|
+
Dim lastRow As Long
|
43
|
+
|
44
|
+
'現在のブック内にあるすべてのシートをループ処理
|
45
|
+
For Each sht In ActiveWorkbook.Worksheets
|
46
|
+
'対象シート内のA列先頭からA列最終データ行までをループ処理
|
47
|
+
For Each rng In sht.Range(sht.Cells(1, 1), sht.Cells(sht.Rows.Count, 1).End(xlUp))
|
48
|
+
'A列が1なら、その行をコピー
|
49
|
+
If sht.Cells(rng.Row, 1) = 1 Then
|
50
|
+
sht.Rows(rng.Row).Copy
|
51
|
+
|
52
|
+
'DBブックを選択し、一番下の行を選択
|
53
|
+
Windows("VBAテスト.xlsx").Activate
|
54
|
+
lastRow = sht.Cells(sht.Rows.Count, 1).End(xlUp).Row + 1
|
55
|
+
|
56
|
+
'値で貼り付け
|
57
|
+
Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _
|
58
|
+
:=False, Transpose:=False
|
59
|
+
End If
|
60
|
+
|
61
|
+
Next rng
|
62
|
+
Next sht
|
63
|
+
|
64
|
+
End Sub
|
65
|
+
```
|