「シート1」のC・E・I・O列の値を図のような配置で「シート3」に値で貼り付けたいです。
「シート1」のグループには空白がある場合があります。
「シート3」にはすでに項目が埋まっている場合があります、仮に5番まで埋まっていたら
次の6番に「シート1」の項目を追加していきたいです。
「シート1」が未入力の場合、そのまま空白を「シート3」の空き項目に値で貼り付けたいです。
「シート1」と同じフォーマットで入力済の「シート2」が存在した場合、同じマクロを実行したとき
「シート3」の空き項目に貼り付けたいからです。
グループに空白があるとどう貼り付ければ良いかわからなくなり、もう降参です。
お詳しい方教えてください、宜しくお願いいたします。
No.3ベストアンサー
- 回答日時:
こんばんは
ご説明の内容がよく理解できないのですが、勝手に想像と空想で埋めて・・・
>グループに空白があるとどう貼り付ければ良いかわからなくなり~
どうしたいのかよくわかりません。
空白だろうが空白でなかろうが、単純に転記するのではダメなのでしょうか?
以下は、単純に転記するだけの例です。(なさりたいこととは違うのかも知れませんが)
※ シートのレイアウトはご提示の添付図の通りと仮定
※ シート名は「シート1」、「シート3」と仮定
Sub Q_13390927()
Dim sh As Worksheet, rw As Long
Dim sRange As Range, dRange As Range
Set sh = Worksheets("シート1")
With Worksheets("シート3")
rw = .Cells(Rows.Count, 3).End(xlUp).Row + 1
rw = Application.Max(Int(rw / 2) * 2 + 1, 11)
Set dRange = .Cells(rw, 3).Resize(2, 5)
End With
For rw = 5 To sh.Cells(Rows.Count, 3).End(xlUp).Row
Set sRange = sh.Cells(rw, 3).Resize(1, 13)
dRange(1).Value = sRange(1).Value
dRange(3).Value = sRange(13).Value
dRange(5).Value = sRange(7).Value
dRange(6).Value = sRange(3).Value
Set dRange = dRange.Offset(2)
Next rw
End Sub
No.2
- 回答日時:
こんばんは
要件が足りていないような・・・
>「シート1」と同じフォーマットで入力済の「シート2」が存在した場合、
これはどういう事でしょうか・・・
「シート1」から「シート3」を作るだけならデータ全てを処理すれば良いけれど・・条件により出力したりしなかったりするのかな?
だとすると「シート1」の5行目だけを対象に「シート3」に追加すれば良いのでしょうか?
「シート1」の全データを対象に加工するのであれば 一例ですが下記の様な処理は参考になりますか
Sub test()
Dim dataRowCount As Long
Dim Ary()
Dim i As Long, n As Long
With Sheets("Sheet1")
dataRowCount = .Range("C5", .Cells(Rows.Count, "C").End(xlUp)).Rows.Count * 2
ReDim Ary(dataRowCount, 4)
For i = 5 To .Cells(Rows.Count, "C").End(xlUp).Row
Ary(n, 0) = .Cells(i, "C")
Ary(n, 2) = .Cells(i, "O")
Ary(n, 4) = .Cells(i, "I")
Ary(n + 1, 0) = "'" & .Cells(i, "E")
n = n + 2
Next
End With
Sheets("Sheet3").Range("C11").Resize(UBound(Ary, 1) + 1, UBound(Ary, 2) + 1).Value = Ary
End Sub
1行を出力する場合(あまり良い方法では無いかも)
Sub test_01()
Dim rng As Range
Dim n As Long
n = 5 '5行目を出力
Set rng = Sheets("Sheet3").Cells(Rows.Count, "C").End(xlUp).Offset(1)
With Sheets("Sheet1")
rng.Offset(, 0) = .Cells(n, "C")
rng.Offset(, 2) = .Cells(n, "O")
rng.Offset(, 4) = .Cells(n, "I")
rng.Offset(1, 0) = "'" & .Cells(n, "E") '文字のようなので
End With
End Sub
'文字のようなので これを実行すると ' がセルに入力されます
入力されているので次の最終行が取得できます(文字列として扱われます)
No.1
- 回答日時:
>「シート1」と同じフォーマットで入力済の「シート2」が存在した場合、>同じマクロを実行したとき
>「シート3」の空き項目に貼り付けたいからです。
この意味がよくわかりません。
提示されたマクロの機能は、シート1の内容をシート3に貼り付けかと思います。
シート2の内容をシート3に貼り付ける機能も、このマクロは持っているのですか?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- その他(Microsoft Office) エクセルマクロ オートフィルターでで選択コピー 2 2022/04/18 11:05
- Visual Basic(VBA) 範囲を指定して別シートにコピペ 2 2022/09/15 07:32
- Visual Basic(VBA) 【VBA】指定した検索条件に一致したら別シートに転記したい 2 2022/03/23 16:14
- Visual Basic(VBA) シート間で同じ値があったら指定範囲をコピーして貼り付け 1 2022/11/07 08:01
- Visual Basic(VBA) シート間で同じ値があったらコピペ 1 2022/05/08 09:39
- Excel(エクセル) エクセルシートのデータを1列飛ばしで別ブックのシートに貼り付けるマクロが知りたい 2 2023/06/05 22:37
- Visual Basic(VBA) vbaエクセルマクロ RemoveDuplicatesについて RemoveDuplicatesを使 3 2023/02/28 01:13
- Visual Basic(VBA) 貼り付けた値が消えていく 以下はソースファイルの2番目のシートのB6から最終行を取得 ターゲットファ 2 2023/07/27 12:23
- Visual Basic(VBA) 別ブックの列同士の値が一致したときの処理 1 2022/09/03 08:27
- Excel(エクセル) 【困っています】VBA 追加処理の記述を教えてください。 1 2022/08/25 22:54
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~12/2】 国民的アニメ『サザエさん』が打ち切りになった理由を教えてください
- ・ちょっと先の未来クイズ第5問
- ・【お題】ヒーローの謝罪会見
- ・これが怖いの自分だけ?というものありますか?
- ・スマホに会話を聞かれているな!?と思ったことありますか?
- ・それもChatGPT!?と驚いた使用方法を教えてください
- ・見学に行くとしたら【天国】と【地獄】どっち?
- ・【大喜利】【投稿~11/22】このサンタクロースは偽物だと気付いた理由とは?
- ・お風呂の温度、何℃にしてますか?
- ・とっておきの「まかない飯」を教えて下さい!
- ・2024年のうちにやっておきたいこと、ここで宣言しませんか?
- ・いけず言葉しりとり
- ・土曜の昼、学校帰りの昼メシの思い出
- ・忘れられない激○○料理
- ・あなたにとってのゴールデンタイムはいつですか?
- ・とっておきの「夜食」教えて下さい
- ・これまでで一番「情けなかったとき」はいつですか?
- ・プリン+醤油=ウニみたいな組み合わせメニューを教えて!
- ・タイムマシーンがあったら、過去と未来どちらに行く?
- ・遅刻の「言い訳」選手権
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・この人頭いいなと思ったエピソード
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
【ExcelVBA】全シートのセルの...
-
特定の文字を含むシートだけマ...
-
ユーザーフォームに入力したデ...
-
VBA実行時エラー1004 ソート失敗
-
IFステートの中にWithステート...
-
Excelマクロのエラーを解決した...
-
実行時エラー'1004': WorkSheet...
-
ブック名、シート名を他のモジ...
-
別のシートから値を取得するとき
-
Excel VBA での計算について…
-
リンク貼り付けをマクロで簡素...
-
userFormに貼り付けたLabelを変...
-
excelのマクロで該当処理できな...
-
コンボボックスの値で参照する...
-
エクセルVBAについて
-
Vba UserformからExcelシートの...
-
異なるシートの配列を参照し、...
-
シート名でファイル検索する
-
ExcelVBA シート名を複数セルか...
-
VBA オートフィルター繰り返し
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
【ExcelVBA】全シートのセルの...
-
特定の文字を含むシートだけマ...
-
excelのマクロで該当処理できな...
-
実行時エラー'1004': WorkSheet...
-
ユーザーフォームに入力したデ...
-
Excelマクロのエラーを解決した...
-
VBAで指定シート以外の選択
-
ブック名、シート名を他のモジ...
-
別のシートから値を取得するとき
-
XL:BeforeDoubleClickが動かない
-
IFステートの中にWithステート...
-
エクセル・マクロ シートの非...
-
【Excel VBA】Worksheets().Act...
-
実行時エラー1004「Select メソ...
-
ExcelVBA:複数の特定のグラフ...
-
エクセルのシート名変更で重複...
-
ExcelのVBAのマクロで他のシー...
-
VBA 存在しないシートを選...
-
シートが保護されている状態で...
-
VBA 検索して一致したセル...
おすすめ情報
すいません、言葉が足りていませんでした。
シート2にも同じようなマクロを追加して実行したときに、シート3の空き項目に貼り付けることも想定しているというだけの事です。特に関係ありません、申し訳ないです。