
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)
-
別シートに空白セルを詰めデータを自動コピー
Excel(エクセル)
-
-
4
エクセルの空白を詰めて別シートに表示
その他(Microsoft Office)
-
5
【EXCEL】【VBA】空欄は飛ばして処理する方法を教えて下さい。
Excel(エクセル)
-
6
VBA 空白セルを削除ではない方法で詰めるやり方
Visual Basic(VBA)
-
7
EXCEL VBA マクロ 別シートの空白行へのコピー
その他(Microsoft Office)
-
8
VBAで空白セルにのみ数値を代入する方法
Excel(エクセル)
-
9
エクセル:マクロ「Application.CutCopyMode = False」って?
Excel(エクセル)
-
10
VBAで指定範囲内の空白セルを左詰めで一括削除したいのですが
Visual Basic(VBA)
-
11
空白行を無視してコピーするマクロについて
Excel(エクセル)
-
12
エクセル2016でfilter関数がないので、、抜き出す関数をおしえてください。
Excel(エクセル)
-
13
VBA 空白行に転記する
Visual Basic(VBA)
-
14
VBA別シートの最終行の次行へ転記したい。
Visual Basic(VBA)
-
15
エクセルで空白セルを含む列の最終行の値を取得する式を教えてください
Excel(エクセル)
-
16
【マクロ】転記ツール。転記先にデータがある場合、上書きするか消すか質問をして欲しい
Excel(エクセル)
-
17
EXCEL VBA で指定した範囲に入力があるかどうか?
Visual Basic(VBA)
-
18
Excel マクロ VBA プロシージャが大きすぎます のエラー対処方法
Visual Basic(VBA)
-
19
Excel 複数のデータを別シートに上から詰めて表示させたい
Excel(エクセル)
-
20
エクセルで複数のシートのクリアをしたいです
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
excel
-
VLOOKUP FALSEのこと
-
if関数の複数条件について
-
エクセルシートの見出しの文字...
-
エクセルでフィルターした値を...
-
エクセルの文字数列関数と競馬...
-
【マクロ】数式を入力したい。...
-
【画像あり】オートフィルター...
-
LibreOffice Clalc(またはエク...
-
【マクロ】excelファイルを開く...
-
【マクロ】実行時エラー '424':...
-
Dir関数のDo Whileステートメン...
-
【マクロ】【画像あり】4つの...
-
【マクロ】エラー【#DIV/0!】が...
-
【Officer360?Officer365?の...
-
空白のはずがSUBTOTAL関数でカ...
-
表計算ソフトでの様式の呼称
-
エクセルに写真が貼れない(フ...
-
【関数】3つのセルの中で最新...
-
【マクロ】【画像あり】4つの...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Excelマクロで空白セルを詰めて...
-
Excel で行を指定回数だけコピ...
-
エクセル:VBAで月変わりで、自...
-
Excel VBA インデックスの境...
-
excelの差込印刷で可視セルだけ...
-
エクセルVBAで 2種のリストを...
-
エクセルVBAで SendKeys "{TAB}"
-
VBA:同じ文字列データの比...
-
歯抜けの時間を埋めて行の挿入
-
VBA別シートの最終行の下行へ貼...
-
VBA 最終行取得からの繰り返し貼付
-
VBA 貼付先範囲(行)がいっぱ...
-
エクセル2007で、マクロで、結...
-
エクセルVBA 別シートの複数の...
-
Excel VBAでシート内全体に非表...
-
Excelマクロ データが上書きさ...
-
EXCELマクロで全シート対...
-
excel:色付き文字の抽出と変換法
-
VBAで条件が一致する行のデータ...
-
データ入力シートから別シート...
おすすめ情報