ここから本文です

A列最終行にあるデータをB列最終行までオートフィルする記述を教えてください。

アバター

ID非公開さん

2013/9/2319:22:15

A列最終行にあるデータをB列最終行までオートフィルする記述を教えてください。

With Cells(1, 1).End(xlUp).Offset(1)
.Value = ActiveSheet.Name
'一番下の案件までオートフィル
.AutoFill Destination:=Range("A" & Cells(Rows.Count, 2).End(xlUp).Row)
End With

閲覧数:
216
回答数:
1

違反報告

ベストアンサーに選ばれた回答

ja7********さん

編集あり2013/9/2322:58:02

> With Cells(1, 1).End(xlUp).Offset(1)
これは、A1をEnd(xlUp)してもA1ですのでxlUpしている意味が、ありません。
End(xlUp)しなくてもOffset(1)では、A2かと・・・ End(xlDown)の間違いかな?

> .AutoFill Destination:=Range("A" & Cells(Rows.Count, 2).End(xlUp).Row)
Destinationは、基準となるデータの入った「セル範囲も」含むようにします。
範囲でなくてはならないのに、これでは、単体セルになっています。

> A列最終行にあるデータをB列最終行までオートフィルする
> .Value = ActiveSheet.Name
この↑コードが、質問内容と違いますが・・・
これでは、何をオートフィルしようとしているのか、判りません。

単に「A列データ最終行を」ということなら こんな感じで如何でしょうか。

Sub test()
Dim Rw As Long
Rw = Cells(Rows.Count, 2).End(xlUp).Row
With Cells(Rows.Count, 1).End(xlUp)
    If .Row < Rw Then
        .AutoFill Destination:=.Resize(Rw - .Row + 1)
    End If
End With
End Sub

'-----------
もし、A列データ最終の次にシート名を入力して、それをB列データ最終行
までオートフィルするなら こんな感じです。

Sub test2()
Dim Rw As Long
Rw = Cells(Rows.Count, 2).End(xlUp).Row
With Cells(Rows.Count, 1).End(xlUp).Offset(1)
    .Value = ActiveSheet.Name
    If .Row + 1 < Rw Then
        .AutoFill Destination:=.Resize(Rw - .Row + 1)
    End If
End With
End Sub

この回答は投票によってベストアンサーに選ばれました!

この質問につけられたタグ

みんなで作る知恵袋 悩みや疑問、なんでも気軽にきいちゃおう!

Q&Aをキーワードで検索:

Yahoo! JAPANは、回答に記載された内容の信ぴょう性、正確性を保証しておりません。
お客様自身の責任と判断で、ご利用ください。
本文はここまでです このページの先頭へ

「追加する」ボタンを押してください。

閉じる

※知恵コレクションに追加された質問は選択されたID/ニックネームのMy知恵袋で確認できます。

不適切な投稿でないことを報告しました。

閉じる