VBA初心者です。
名前が一致した別ブックに転記していく作業ですが、全く分かりません。
動画や本を読んでいるのですが、わからないのでご教授いただける方がいましたら
お願い致します。
https://i.gyazo.com/4ecdc8983c4792f7b2399b3f07c4 …
上のシート名(ここではAさんとしておきます。)の同じ色の部分の数字を
別ブックの同じシートの同じところに転記していくマクロです。
https://i.gyazo.com/72d879bbb255b9a6a7c8f6fc3e73 …
上記のブックの『Aさん』を開くと
https://i.gyazo.com/6a1c7ae407e1d7cc9d6a5edef871 …
ここに転記していく様にしたいのですが、うまくいきません。
サンプルではA~Fまでですが、実際は30シートくらいあります。
名前が一致した別ブックに転記していく方法を是非ともご教授お願いします。
No.3ベストアンサー
- 回答日時:
以下のマクロを標準モジュールに登録してください。
Const Folder As String = "D:\goo\data8\転記"
は、Aさん.xlsx等のブックを格納してあるフォルダ名です。
あなたの環境にあわせて適切に設定してください。
----------------------------------------
Option Explicit
Public Sub ブック間転記()
Const Folder As String = "D:\goo\data8\転記"
Dim ms As Worksheet
Dim wb As Workbook
Dim ws As Worksheet
Dim path As String
For Each ms In Worksheets
path = Folder & "\" & ms.Name & ".xlsx"
If Dir(path) = "" Then
MsgBox (path & "が存在しません")
Exit Sub
End If
Set wb = Workbooks.Open(path)
Set ws = wb.Worksheets("お申し出報告書")
ws.Cells(5, "E").Value = ms.Cells(6, "S").Value
ws.Cells(6, "E").Value = ms.Cells(6, "T").Value
ws.Cells(7, "E").Value = ms.Cells(6, "U").Value
ws.Cells(8, "E").Value = ms.Cells(6, "V").Value
wb.Save
wb.Close
Next
MsgBox ("完了")
End Sub
No.2
- 回答日時:
No1です。
>転記する同じ名前のブックは違うフォルダに格納しています。
>その場合はどうするのでしょうか?
フルパスで指定すれば問題はありません。
パスは文字列ですので直接指定しても良いですし、No1の例のように文字列演算でパスを作成しても良いです。
No.1
- 回答日時:
こんにちは
ご質問文からでは、どこがわからないのかが不明ですけれど・・・
シート名は worksheet.Name で取得できるので問題はないでしょうから、
>名前が一致した別ブックに転記していく方法を是非ともご教授お願いします。
ブックを探せればよいということでしょうか?
ブックは同じフォルダー内にあるようですから、
Dir(フォルダパス & "\" & ファイル名 & ".xlsx")
で検索すれば、対象ブックの有無を確認できます。
(存在しない場合は、空文字が返されます)
https://learn.microsoft.com/ja-jp/office/vba/lan …
必ずブックは存在するという保証があるのなら、わざわざ確認する必要もないので、直接ブックを開けば良いだけですね。
https://learn.microsoft.com/ja-jp/office/vba/api …
後は、普通にセルの値を転記するだけでしょうから、問題は無いものと推測します。
>同じ色の部分の数字を別ブックの同じシートの同じところに転記していく~
って、まさか、色だけが手掛かりでセルの位置を探して、そこに転記するって意味ではないですよね?
もしもそうなら、セルの Interior.Color をキーにして検索するというひと手間が必要になるでしょう。
また、その場合には、該当セルが複数存在する場合や存在しない場合にどうするのかなどの処理についても、あらかじめ考えておく必要があります。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) 【困っています】VBA 追加処理の記述を教えてください。 1 2022/08/25 22:54
- Excel(エクセル) 【関数】【マクロ】データの転記の方法について 2 2023/07/26 15:22
- Excel(エクセル) vba 同じブック内での転記について 4 2023/01/15 14:42
- Visual Basic(VBA) 【困っています2】VBA 追加処理の記述を教えてください。 2 2022/08/26 11:42
- Visual Basic(VBA) 特定の文字を含むシートだけマクロ処理をしたい 1 2023/05/22 01:43
- その他(Microsoft Office) マクロVBAについて 1 2022/09/06 18:12
- Visual Basic(VBA) 該当セルの値を別ブックのシート名と一緒であればコピーしてほしい 1 2022/11/10 20:12
- Visual Basic(VBA) 複数ブックの統合について Excel VBA 1 2022/05/13 09:48
- Visual Basic(VBA) vbaについて 主に以下のような設定をしたいです。 Aブックの表の行数が20未満だったら Bブックの 1 2023/06/08 23:40
- Excel(エクセル) excelのindirect関数の別ブック参照について質問です。 1 2022/06/03 15:17
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
別ブックをダイアログボックス...
-
VBA シートをコピーする際に Co...
-
【ExcelVBA】zip圧縮されたCSV...
-
VBA 別ブックからコピペしたい...
-
エクセルVBAが途中で止まります
-
【困っています2】VBA 追加処...
-
ワイルドカード「*」を使うとう...
-
ユーザーフォームの切り替えに...
-
vbaでvbaProjectのパスワード解...
-
異なるブック間でのセル範囲の...
-
VBA シート名が一致した場合の...
-
EXCEL VBA 単語置き換え につい...
-
【VBA】全シートの計算式を全て...
-
元データ(ピボッド)を開かずマ...
-
vbaについて 主に以下のような...
-
エクセルのマクロを使ってメー...
-
エクセルのマクロについて教え...
-
ExcelのVBAです。フォルダ内の...
-
VBAで別ブックのシートを指定し...
-
シートをコピーする下記記述で...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
VBA シートをコピーする際に Co...
-
エクセルVBAが途中で止まります
-
別ブックをダイアログボックス...
-
【ExcelVBA】インデックスが有...
-
ワイルドカード「*」を使うとう...
-
【ExcelVBA】VBA実行でダイアロ...
-
ExcelのVBAです。フォルダ内の...
-
フォルダ内の全てのファイルに...
-
VBA コードを実行すると画面が...
-
VBA 別ブックからコピペしたい...
-
VBAで別ブックのシートを指定し...
-
VBS Bookを閉じるコード
-
vbaでvbaProjectのパスワード解...
-
【VBA】全シートの計算式を全て...
-
VBA シート名が一致した場合の...
-
【ExcelVBA】zip圧縮されたCSV...
-
複数のエクセルブックをひとつ...
-
VBSでExcelのオープン確認
-
VBAで別のブックにシートをコピ...
-
【Excel VBA】書き込み先ブック...
おすすめ情報
ありがとうございます。
色は分かりやすい様に塗っているだけで
実際はセル番地を入力して行こうと思っています。
転記する同じ名前のブックは違うフォルダに格納しています。
その場合はどうするのでしょうか?