
Sheet1のようなデータを空白セルを詰める形でSheet2に貼り付けたいと考えています(図を参照)。
1行だけであれば下記のコードでできるところまではたどり着きました。
Sub 空白を詰める()
Dim i As Long
Dim j As Long
Dim k As Long
Dim sh1 As Worksheet
Dim sh2 As Worksheet
Set sh1 = Sheets("Sheet1")
Set sh2 = Sheets("Sheet2")
i = sh1.Cells(1, Columns.Count).End(xlToLeft).Column
j = 1
For k = 1 To i
If sh1.Cells(1, k) <> "" Then
sh2.Cells(1, j) = sh1.Cells(1, k)
j = j + 1
End If
Next k
End Sub
複数行のデータに対して同様の処理を行うにはどうすればよいでしょうか?
ご教示願います。

No.2ベストアンサー
- 回答日時:
こんにちは
A列の最終行がデータの最終行と一致しない場合は
SpecialCells(xlLastCell).Rowを使うと良いかもしれません
また、最終列が行によって違う場合は 変数で対象行を指定するか同様に
Range("A1").SpecialCells(xlLastCell).Columnなどを使用しますが
この場合、最大(最後の)行まで処理されるので無駄な処理がされる可能性があります
ご質問のロジックの延長で1例はこんな感じ
ステップ実行などで動作を確認してみてください
Dim i As Long
Dim j As Long
Dim k As Long
Dim sh1 As Worksheet
Dim sh2 As Worksheet
Set sh1 = Sheets("Sheet1")
Set sh2 = Sheets("Sheet2")
Dim n As Long
i = 1
For n = 1 To sh1.Range("A1").SpecialCells(xlLastCell).Row
j = 1
For k = 1 To sh1.Cells(n, Columns.Count).End(xlToLeft).Column
If sh1.Cells(n, k) <> "" Then
sh2.Cells(i, j) = sh1.Cells(n, k)
j = j + 1
End If
Next k
i = i + 1
Next n
ご回答いただきありがとうございます。
うまくできました!
Sheet1のA列には全行データがある状態ですので、列方向のみケアすればよいと思いますが、データ行が多い場合は確かに余計な処理を行うことになりますね。実データで挙動を確認してみます。
ありがとうございました。
No.5
- 回答日時:
こんばんは
詰めるというよりも、空白セルをまとめて除去すると考えると簡単だと思います。
以下のような要領でも可能と思います。
Sub Sample()
With Worksheets("Sheet2")
Worksheets("Sheet1").Cells.Copy .Cells
.UsedRange.SpecialCells(xlCellTypeBlanks).Delete (xlShiftToLeft)
End With
End Sub
こんばんは。
ご回答いただきありがとうございます。
なるほど。こういうアプローチもありですね。
構文もシンプルですし面白いですね。
参考になります。
No.4
- 回答日時:
>>全データ中の列maxを取得する方法はありますでしょうか?
ゴメン、見落とし有りました
i = sh1.Cells(1, Columns.Count).End(xlToLeft).Column
↓1を行に変更
i = sh1.Cells(行, Columns.Count).End(xlToLeft).Column
No.1
- 回答日時:
今のforループを囲むforループを追加する。
囲むforループを行方向でループさせる。
行max= sh1.Range("A65536").End(xlUp).Row ←追加
for 行=1 to 行max ←追加
i = sh1.Cells(1, Columns.Count).End(xlToLeft).Column
j = 1
For k = 1 To i
If sh1.Cells(行, k) <> "" Then ←1を行に変更
sh2.Cells(行, j) = sh1.Cells(行, k) ←1を行に変更
j = j + 1
End If
Next k
Next 行 ←追加
ご回答いただきありがとうございます。
教えていただいたコードを追加してみました。
2行目 かきくけ
3行目 さしすせ
となってしまいますね。
i(列のmax)を1行目で取ってしまっているからだと思いますが、全データ中の列maxを取得する方法はありますでしょうか?
重ねてのお尋ねになり申し訳ありません。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) Excel VBA 文字列のセルを反映させたいです 2 2024/02/24 00:06
- Visual Basic(VBA) Excel VBA マクロ あるフォルダー内の複数のファイルを統合したいです 1 2024/02/19 21:37
- Visual Basic(VBA) VBAコードが作動しません。修正したいのですが何処に原因かあるか教えて下さい。 1 2024/01/08 16:23
- Excel(エクセル) 3つのマクロを連続実行の中で、1つ目のマクロ要件を満たさなかったら、マクロ2・3を実行しない為には 1 2023/10/15 13:42
- Visual Basic(VBA) マクロで最終行を取得したい 4 2023/05/28 12:14
- Visual Basic(VBA) クリップボードに貼付している文字列が、マクロで別ブックへ転記すると、消えてしまう 1 2023/10/15 13:36
- Visual Basic(VBA) コード名シートA列と集計シートA列のコードが一致したら、コード名シートA5からk12の範囲をコピーし 1 2022/08/29 23:46
- Visual Basic(VBA) VBAで、シート間の転記するコードをFOR~NEXTで教えてください。 9 2023/04/30 20:04
- Visual Basic(VBA) フォルダの場所を可変にしたいです(マクロ) 4 2023/05/11 10:00
- Visual Basic(VBA) VBAコードが作動せず、どこに問題があるのか教えて下さい。 3 2023/06/13 13:20
このQ&Aを見た人はこんなQ&Aも見ています
-
マクロで空白セルを詰めて別シートに転記
Visual Basic(VBA)
-
空白セルをとばして転記
Visual Basic(VBA)
-
別シートに空白セルを詰めデータを自動コピー
Excel(エクセル)
-
-
4
VBA 空白セルを削除ではない方法で詰めるやり方
Visual Basic(VBA)
-
5
VBAで空白セルにのみ数値を代入する方法
Excel(エクセル)
-
6
エクセルの空白を詰めて別シートに表示
その他(Microsoft Office)
-
7
EXCEL VBA で指定した範囲に入力があるかどうか?
Visual Basic(VBA)
-
8
エクセル:マクロ「Application.CutCopyMode = False」って?
Excel(エクセル)
-
9
空白行を無視してコピーするマクロについて
Excel(エクセル)
-
10
【EXCEL】【VBA】空欄は飛ばして処理する方法を教えて下さい。
Excel(エクセル)
-
11
VBA 空白行に転記する
Visual Basic(VBA)
-
12
Excel 複数のデータを別シートに上から詰めて表示させたい
Excel(エクセル)
-
13
VBAで指定範囲内の空白セルを左詰めで一括削除したいのですが
Visual Basic(VBA)
-
14
数式による空白を無視して最終行までコピーするマクロ
Excel(エクセル)
-
15
VBAのオートフィルターで該当行がない場合に処理を止めたい
Excel(エクセル)
-
16
エクセルマクロで偶数行(又は奇数行)にあるセルを選択したい
Excel(エクセル)
-
17
excel VBA 2つのシートの特定の列を比較して同じ値のセルがあったらその行を上書きしたい
Excel(エクセル)
-
18
エクセルで空白セルを含む列の最終行の値を取得する式を教えてください
Excel(エクセル)
-
19
エクセルで複数列を1列にまとめるマクロ
Excel(エクセル)
-
20
VBA別シートの最終行の次行へ転記したい。
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Excelマクロで空白セルを詰めて...
-
Excel で行を指定回数だけコピ...
-
Excel VBA インデックスの境...
-
VBA 貼付先範囲(行)がいっぱ...
-
Excelでデータの抽出&別シート...
-
歯抜けの時間を埋めて行の挿入
-
Excel VBAでシート内全体に非表...
-
スマホ機種変更で旧機種のGoogl...
-
機種変更時にデータは見られる?
-
FOMAカード(UIM)異常
-
拡張子「.HUF(.huf)」のファ...
-
画面が真っ暗に・・・
-
DSの「プレイやん」とは?
-
I・O DATA外付けHD(HDCN-U500)...
-
ハードディスクの電源が入らない
-
パソコンの修理業者の対応につ...
-
microSDHCへの音楽取り込み
-
附属の充電器を海外でつかうと!?
-
携帯電話番号を英語で?
-
ソフトバンクからドコモに変更...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Excelマクロで空白セルを詰めて...
-
VBA:同じ文字列データの比...
-
Excel で行を指定回数だけコピ...
-
エクセル:VBAで月変わりで、自...
-
Excel VBA インデックスの境...
-
excelの差込印刷で可視セルだけ...
-
エクセルVBAで 2種のリストを...
-
EXCELマクロで全シート対...
-
エクセルVBAで SendKeys "{TAB}"
-
VBA別シートの最終行の下行へ貼...
-
エクセルVBA 別シートの複数の...
-
Excel VBAでシート内全体に非表...
-
エクセルVBAで実行時エラー...
-
Excel VBA元データから別シー...
-
VBA 最終行取得からの繰り返し貼付
-
vbaでコントロールブレイク
-
歯抜けの時間を埋めて行の挿入
-
VBAで複雑な構成の転記
-
VBAで条件が一致する行のデータ...
-
Excelマクロ データが上書きさ...
おすすめ情報