
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の時刻の不思議
Excel(エクセル)
-
-
4
別シートに空白セルを詰めデータを自動コピー
Excel(エクセル)
-
5
【Excel】版が同じ事を示す番号を生成したい
Excel(エクセル)
-
6
Excelの複数条件の関数
Excel(エクセル)
-
7
今まで文字化けなく開けていたcsvファイルが、文字化けするようになりました。 解決策を教えて頂きたい
Excel(エクセル)
-
8
エクセル 入力があった場合のみ隣の関数を表示
Excel(エクセル)
-
9
考えた式の戻り値が期待通りにならない
Excel(エクセル)
-
10
excelVBAについて。
Excel(エクセル)
-
11
【マクロ】フォルダ内にあるPDFを合体させるには?有料版adobe必要?
Excel(エクセル)
-
12
複数のテキストファイルをexcelでそれぞれ別シートにUTF-16で書き出したい
Excel(エクセル)
-
13
8:40までの出勤は全て8:30にする関数を教えて下さい!!
Excel(エクセル)
-
14
Excelの区切り文字について質問です。 Excel機能にある、区切り文字を使う時に区切ったあとの書
Excel(エクセル)
-
15
この様式の雛形を作るとしたら簡単なのはエクセルですか?
その他(Microsoft Office)
-
16
VBA コードどこがおかしいですか?
Visual Basic(VBA)
-
17
エクセルのマクロについて教えてください。
Visual Basic(VBA)
-
18
エクセルでの2項目比較および抽出方法について
Excel(エクセル)
-
19
「cells」が上手く機能しない
Excel(エクセル)
-
20
(マクロ)参照渡しにて、違う変数でも 渡せるのはなぜですか?
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Excel VBA インデックスの境...
-
Excelマクロで空白セルを詰めて...
-
エクセル2007で、マクロで、結...
-
【WORD差し込み印刷】複数レコ...
-
エクセル:VBAで月変わりで、自...
-
VBA:同じ文字列データの比...
-
Excelでデータの抽出&別シート...
-
VBA 貼付先範囲(行)がいっぱ...
-
エクセルVBA 別シートの複数の...
-
Excel で行を指定回数だけコピ...
-
Excel VBAでシート内全体に非表...
-
vbaでコントロールブレイク
-
Excelで最後まで計算式を...
-
エクセルVBAで SendKeys "{TAB}"
-
《エクセル》リストから同じ分...
-
Excel 蓄積された売上データを...
-
VBA 最終行取得からの繰り返し貼付
-
外付けHDDをフローリングに落と...
-
機種変更時にデータは見られる?
-
パソコンに音楽を取り込みたい...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Excel で行を指定回数だけコピ...
-
Excel VBA インデックスの境...
-
VBA:同じ文字列データの比...
-
エクセル:VBAで月変わりで、自...
-
Excelマクロで空白セルを詰めて...
-
excelの差込印刷で可視セルだけ...
-
VBA別シートの最終行の下行へ貼...
-
エクセルVBAで 2種のリストを...
-
VBAで条件が一致する行のデータ...
-
Excelマクロ データが上書きさ...
-
WorkbooksとWorksheetsを簡単に...
-
VBA 貼付先範囲(行)がいっぱ...
-
ExcelVBAで改ページを追加したい
-
【WORD差し込み印刷】複数レコ...
-
エクセルVBAで SendKeys "{TAB}"
-
Excel VBAでシート内全体に非表...
-
Excel VBA :2回目以降実行で貼...
-
Excel VBA 複数条件にマッチし...
-
エクセル2007で、マクロで、結...
-
Excel VBA元データから別シー...
おすすめ情報