電子書籍の厳選無料作品が豊富!

VBA初心者です
特定の条件を満たすセルの隣接する指定のセルをコピーして別のシートへ貼付けたいです


【sheet1】

A   B   C   ~   F  G

1   2   あ   ~   3  あり
2   1   い   ~   7  なし
3   2   う   ~   4  あり
5   3   え   ~   6  あり
6   2   お   ~   5  なし
7   1   か   ~   3  あり
8   3   き   ~   7  なし
9   2   く    ~  8  なし

といったデータのうち、G列が「あり」の行の
C~Fの値を別のシートへ以下のように貼り付けたいです

【sheet2】

A   ~   D  E

あ   ~   3  _
う   ~   4  _
え   ~   6  _
か   ~   3  _


全くの初心者です
よろしくお願いします

A 回答 (2件)

Sheet1がアクティブな時しかうまくいきませんが、


こんな感じでどうでしょう。
適当に作ってるので、非常にパフォーマンス悪いですが・・・。


Public Sub cptest()
Dim sht1 As Worksheet
Dim sht2 As Worksheet
Dim rng As Range
Dim cel As Range
Dim stcrng As New Collection
Dim lastRow As Integer
Dim cnt As Integer
Set sht1 = ThisWorkbook.Worksheets("Sheet1")
Set sht2 = ThisWorkbook.Worksheets("Sheet2")
lastRow = Range("G65535").End(xlUp).Row
Set rng = sht1.Range("G1:G" & lastRow)
For Each cel In rng
If cel.Value = "あり" Then
Set cel = sht1.Range(cel.Offset(0, -4), cel.Offset(0, -1))
stcrng.Add cel
End If
Next

sht2.Cells.Clear
cnt = 0
Set rng = sht2.Range("A1")
For Each cel In stcrng
cel.Copy
rng.Offset(cnt, 0).PasteSpecial
rng.Offset(cnt, 4).Value = "_"
cnt = cnt + 1
Next
Application.CutCopyMode = False
End Sub
    • good
    • 2
この回答へのお礼

思っていた通りのものができました
ありがとうございます
中身はまたゆっくり学んでいきます

お礼日時:2012/04/19 19:17

Sheet2を全てクリアして、1行目からデータが始まります。


Sub Macro1()
Set ws01 = Sheets("Sheet1")
Set ws02 = Sheets("Sheet2")
ws02.Cells.ClearContents
myRow = 0
For i = 1 To ws01.Range("G65535").End(xlUp).Row
If ws01.Range("G" & i) = "あり" Then
myRow = myRow + 1
ws02.Range("A" & myRow & ":D" & myRow).Value = ws01.Range("C" & i & ":F" & i).Value
End If
Next i
End Sub
    • good
    • 1
この回答へのお礼

締め切ってしまった瞬間に投稿いただきました
書式はコピーされないのでこちらはこちらで活用させていただきます
ありがとうございました

お礼日時:2012/04/19 19:18

お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!

このQ&Aを見た人はこんなQ&Aも見ています


おすすめ情報

このQ&Aを見た人がよく見るQ&A