
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で質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
マクロで空白セルを詰めて別シートに転記
Visual Basic(VBA)
-
空白セルをとばして転記
Visual Basic(VBA)
-
エクセルの空白を詰めて別シートに表示
その他(Microsoft Office)
-
-
4
別シートに空白セルを詰めデータを自動コピー
Excel(エクセル)
-
5
【EXCEL】【VBA】空欄は飛ばして処理する方法を教えて下さい。
Excel(エクセル)
-
6
VBA 空白セルを削除ではない方法で詰めるやり方
Visual Basic(VBA)
-
7
VBAで空白セルにのみ数値を代入する方法
Excel(エクセル)
-
8
エクセル:マクロ「Application.CutCopyMode = False」って?
Excel(エクセル)
-
9
VBAで指定範囲内の空白セルを左詰めで一括削除したいのですが
Visual Basic(VBA)
-
10
空白行を無視してコピーするマクロについて
Excel(エクセル)
-
11
エクセル2016でfilter関数がないので、、抜き出す関数をおしえてください。
Excel(エクセル)
-
12
EXCEL VBA で指定した範囲に入力があるかどうか?
Visual Basic(VBA)
-
13
VBA 空白行に転記する
Visual Basic(VBA)
-
14
Excel マクロ VBA プロシージャが大きすぎます のエラー対処方法
Visual Basic(VBA)
-
15
ExcelVBAを使って、値がある場合は作業を繰り返し実行するプログラムを作成したい。
Visual Basic(VBA)
-
16
Excel 複数のデータを別シートに上から詰めて表示させたい
Excel(エクセル)
-
17
エクセルで複数のシートのクリアをしたいです
Excel(エクセル)
-
18
EXCEL VBA マクロ 別シートの空白行へのコピー
その他(Microsoft Office)
-
19
数式による空白を無視して最終行を取得するマクロ
Excel(エクセル)
-
20
Application.ScreenUpdating = Falseが効きません
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルのVBAで集計をしたい
-
【マクロ】変数に入れるコード...
-
【マクロ】実行時エラー '424':...
-
エクセルのリストについて
-
エクセルの関数について
-
【マクロ】元データと同じお客...
-
【マクロ】左のブックと右のブ...
-
【マクロ】数式を入力したい。...
-
【マクロ】【相談】Excelブック...
-
【画像あり】オートフィルター...
-
【マクロ】【配列】3つのシー...
-
他のシートの検索
-
Office2021のエクセルで米国株...
-
vba テキストボックスとリフト...
-
エクセルの複雑なシフト表から...
-
【関数】3つのセルの中で最新...
-
LibreOffice Clalc(またはエク...
-
【マクロ】excelファイルを開く...
-
エクセルシートの見出しの文字...
-
【関数】=EXACT(a1,b1) a1とb1...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Excelマクロで空白セルを詰めて...
-
Excel で行を指定回数だけコピ...
-
Excel VBA インデックスの境...
-
VBA:同じ文字列データの比...
-
excelの差込印刷で可視セルだけ...
-
エクセル:VBAで月変わりで、自...
-
VBAで条件が一致する行のデータ...
-
VBA 貼付先範囲(行)がいっぱ...
-
VBAでのシートの色が
-
複数ブックの複数セルの抽出教...
-
エクセルVBAで 2種のリストを...
-
【WORD差し込み印刷】複数レコ...
-
別シートから検索値に一致した...
-
Excelマクロ データが上書きさ...
-
ExcelVBA、印刷ページを事前に...
-
VBA別シートの最終行の下行へ貼...
-
エクセルでデータの検索
-
Excel VBAでシート内全体に非表...
-
[EXCEL]全てのチェックボックス...
-
VBA 最終行取得からの繰り返し貼付
おすすめ情報