- ベストアンサー
エクセルのマクロで転記
シート1とシート2があり、 シート1の20Aから39Lまでのセルの中に情報を書き込んでいます。 シート1の20Lから39LのL行で、数値が入っているセルがあれば、その行のA、B、I、L列と、J2、A7を取り出し、シート2の2行目から下に転記していくのですが、 シート2のA列にはシート1のJ2を、B列にはシート1のA7を、C列以降は、シート1のA、B、I、Lを入れるようにします。 また同じ条件がシート1で発生すれば、シート2の3行目以降に転記していく感じです。 どのようにすればいいでしょうか。
- みんなの回答 (1)
- 専門家の回答
質問者が選んだベストアンサー
無意味に難しくしなくても、丁寧に転記していくだけの単純作業です。 sub macro1() dim i as long dim r as long r = 1 for i = 20 to 39 if cells(i, "L") <> "" and isnumeric(cells(i, "L").value) then r = r + 1 worksheets("Sheet2").cells(r, "A") = worksheets("Sheet1").range("J2") worksheets("Sheet2").cells(r, "B") = worksheets("Sheet1").raneg("A7") worksheets("Sheet2").cells(r, "C") = worksheets("Sheet1").cells(i, "A") worksheets("sheet2").cells(r, "D") = worksheets("Sheet1").cells(i, "B") worksheets("Sheet2").cells(r, "E") = worksheets("Sheet1").cells(i, "I") worksheets("Sheet2").cells(r, "F") = worksheets("Sheet1").cells(i, "L") end if next i end sub みたいな。 #L列に数式を記入しているのか生数字を記入しているのかなどによっても工夫代がありますが、まぁこの程度の行数なら一行ずつ舐めていっても大したことありません。