• ベストアンサー

エクセルのマクロで転記

シート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行目以降に転記していく感じです。 どのようにすればいいでしょうか。

質問者が選んだベストアンサー

  • ベストアンサー
  • keithin
  • ベストアンサー率66% (5278/7941)
回答No.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列に数式を記入しているのか生数字を記入しているのかなどによっても工夫代がありますが、まぁこの程度の行数なら一行ずつ舐めていっても大したことありません。

関連するQ&A