他ブックのシートの範囲を選択しコピーした内容を、別ブックのシート
に貼り付けするマクロを作成しています。
現在の情報であれば、下記のマクロで解決できます。
Sub Test1()
Dim myCellall As Range
Dim myCellsom As Range
Dim myCelluri As Range
Set myCellall = Sheets("すべて").Range("A1")
Set myCellsom = Sheets("総務").Range("A1")
Set myCelluri = Sheets("売上").Range("A1")
With Workbooks.Open("\")
.Worksheets("すべて").Range("A1:K17").Copy myCellall
.Worksheets("総務").Range("A1:K88").Copy myCellsom
.Worksheets("売上").Range("A1:K81").Copy myCelluri
.Close False
End With
End Sub
ただ、他ブックのシートのデータは変動するため、行と列の変更を行わなければいけません。行と列の増減があっても、自動的に対応できるマクロを書きたいと思います。
どのようなマクロを追加すればよろしいでしょうか。
よろしくお願いいたします。
No.2ベストアンサー
- 回答日時:
A1から始まる範囲をA1から始まる範囲にコピーするだけなら,
ケース1)
workbooks("元.xls").worksheets("すべて").cells.copy thisworkbook.worksheets("すべて").range("A1")
でも十分です。
ケース2)
application.displayalerts = false
thisworkbook.worksheets("すべて").delete
workbooks("元.xls").worksheets("すべて").copy before:=thisworkbook.worksheets(1)
とか,
あるいは所定のシートをひっくるめにしてコピーしてしまっても良いかもしれません。
workbooks("元.xls").worksheets(array("すべて","総務","売上")).copy before:=thisworkbook.worksheets(1)
ケース3)
セル番地をちゃんと指定しないとどうしてもキモチワルイなら
with workbooks.open("~")
with .worksheets("全て")
.range(.range("A1"), .cells.specialcells(xlcelltypelastcell)).copy mycellall
end with
end with
などのような手もありますね。
No.1
- 回答日時:
>ただ、他ブックのシートのデータは変動するため、行と列の変更を行わなければいけません。
行列の変更の条件は何でしょう?
条件が分らなければ回答が出来ませんよ
例えば
値のあるすべてのセルを選択するなら
次のようになります
Sub Test1()
Dim myCellall As Range
Dim myCellsom As Range
Dim myCelluri As Range
Set myCellall = Sheets("すべて").Range("A1")
Set myCellsom = Sheets("総務").Range("A1")
Set myCelluri = Sheets("売上").Range("A1")
With Workbooks.Open("\")
.Worksheets("すべて").UsedRange.Copy myCellall
.Worksheets("総務").UsedRange.Copy myCellsom
.Worksheets("売上").UsedRange.Copy myCelluri
.Close False
End With
End Sub
参考まで
ご回答ありがとうございました。詳細な条件を記載せず、申し訳ございませんでした。UsedRangeプロパティは知らなかったので勉強になりました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルのマクロで指定条件一...
-
エクセルの複数シートの保護を...
-
Excelで金銭出納帳。繰越残高を...
-
別シート参照のセルをシート毎...
-
excelでシート毎の最終更新日を...
-
前の(左隣の)シートを連続参...
-
VBAでシートコピー後、シート名...
-
シート名ではなく、相対位置で...
-
エクセルで、「1つ前のシート...
-
エクセルで複数設定したハイパーリンク先...
-
EXCEL:同じセルへどんどん足し...
-
整数行を残し小数点の行を削除...
-
Excel(VBA)データ入力に応じて...
-
EXCEL VBAで別のシー...
-
シートを追加・名前を次月に変...
-
エクセルのシートを増やす
-
特定のシートの削除を禁止した...
-
条件に応じて特定の行を非表示...
-
Excel2007で、太字にした行のみ...
-
シート番号からシート名を取得する
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
シートをコピーして シートに...
-
エクセルのマクロで指定条件一...
-
【マクロ】毎回、ファイル名が...
-
Excelでシート名と最終更新日を...
-
Excel シートを自動作成、セル...
-
Excel マクロ 他ブックのシート...
-
【マクロ】顧客番号にて一致さ...
-
プロジェクトロックしてあるシ...
-
転記マクロの作成
-
エクセルのマクロ設定について...
-
新しいマクロの記録でコピーし...
-
エクセルVBA 行列を一気に変換...
-
エクセルのマクロ設定について...
-
エクセルの複数シートの保護を...
-
Excelで金銭出納帳。繰越残高を...
-
条件に応じて特定の行を非表示...
-
エクセルVBAでパスの¥マークに...
-
前の(左隣の)シートを連続参...
-
Excel2007で、太字にした行のみ...
-
EXCEL:同じセルへどんどん足し...
おすすめ情報