
1つのファイルを選択後、
そのファイルを開いてある操作をし、閉じる。
その後自動的に、同一フォルダ内のファイルを開いて同様の操作をし、閉じる。
これをフォルダ内のファイル全てに対して行う、
というマクロを組みたいです。
例えば、
フォルダAに、File1.csv, File2.csv, File3.csv, File4.csv の4ファイルがある時、
File3.csvを選んで操作を実行(csvファイル内のセルA4の値を、マクロを実行したExcelファイルにコピー)。
実行完了後、File3.csvは閉じる。
続けて、File1,File2,File4についても、
開く→コピーする→閉じる、を繰り返す。
フォルダ内全てのファイルに対して実行したら終了。
ファイル名は、常にFile+数字.csvではありませんが、拡張子は常にCSVです。
素人考えでは、フォルダ内のファイルの数と名前を取得し、ループで回せばいいと思うのですが、
「フォルダ内のファイルの数と名前を取得」する関数でもあるのでしょうか?
他に何か楽な方法でもあれば、教えてください。
No.3ベストアンサー
- 回答日時:
Dir関数でやってみました。
このマクロを記述したエクセルのBOOKと同じフォルダ内のすべてのcsvファイルを開き、A4の値を取得します。
Sub test01()
Dim MyFile As String, MyPath As String
Dim i As Long
Dim wb As Object
MyPath = ThisWorkbook.Path & "\" '自分のパスを取得
MyFile = Dir(MyPath & "*.csv", vbNormal) 'パス内のcsvファイル
Do Until MyFile = "" '対象ファイルがなくなるまで
Set wb = Workbooks.Open(MyPath & "\" & MyFile) '選択したファイルを開く
i = i + 1
ThisWorkbook.Sheets("Sheet1").Cells(i, 1).Value = wb.Sheets(1).Range("A4").Value '転記
wb.Close (False) '選択したファイルを閉じる
MyFile = Dir '次のファイルを検索
Set wb = Nothing
Loop '繰り返し
End Sub
回答ありがとうございます。
>Workbooks.Open(MyPath & "\" & MyFile)
など、今まで知らなかった書き方を見ることができ、大変参考になります。
目的のマクロは、無事組むことができました。
No.2
- 回答日時:
FileSystemObjectを使うのであれば、こんな感じかな。
Microsoft Scripting Runtime を参照設定してください。
Public Sub Proc1()
Dim fso As New FileSystemObject
Dim fo As Folder
Dim fi As File
Dim wbk As Workbook
Set fo = fso.GetFolder("~フォルダ名~")
For Each fi In fo.Files
Set wbk = Workbooks.Open(fi.Name)
(中のロジックはご自分で組み立ててください)
Set wbk = Nothing
Next fi
Set fi = Nothing
Set fo = Nothing
Set fso = Nothing
End Sub
お役に立てれば幸いです。
回答ありがとうございます。
無事動作しました。
しましたが、挙げていただいたコードにはまだ私にはわからない部分もあるので、
今後調べていこうと思います。
No.1
- 回答日時:
DIR関数やFileSystemObjectなどいろいろありますが。
ブックマークしておくと良いサイトがあります。
いつも利用させてもらってる「OfficeTANAKA」さんのページ。サンプル満載です。
リンクフリーの記述があるので、リンク貼ります。
http://www.officetanaka.net/
ここらあたりか?
http://www.officetanaka.net/excel/vba/file/file0 …
回答ありがとうござます。
サンプルや解説のページはいくつかブックマークしておりましたが、
こちらは知りませんでした。
参考にさせていただきます。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- PHP 値の取り出し方について教えて下さい。 1 2023/03/31 13:30
- その他(プログラミング・Web制作) セレクトボックスで選択された値をコントローラーで使用したい 2 2022/07/26 16:41
- Visual Basic(VBA) 複数のcsvファイルをExcelに一括変換したい 2 2023/03/03 12:44
- Visual Basic(VBA) vbaの構文の修正相談(xmlファイルを順に開いてコピペ作業) 1 2023/04/22 01:18
- Access(アクセス) access,vbaでフォルダ内のファイルをテーブルにインポート、ファイル名もフィールドに追加したい 1 2022/08/31 11:11
- Visual Basic(VBA) VBA This Workbookモジュールを別ファイルにコピーする方法 1 2022/09/14 01:51
- Visual Basic(VBA) VBAが止まります。 2 2022/09/02 14:02
- その他(コンピューター・テクノロジー) <a href="file:///フォルダ名/ファイル名">リンクテキスト</a>について 1 2023/04/06 22:40
- Visual Basic(VBA) vbaのエラー対応(実行時エラー7:メモリが不足しています) 4 2023/04/24 00:20
- Visual Basic(VBA) エクセルのマクロについて教えてください。 4 2023/05/24 08:33
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・「それ、メッセージ花火でわざわざ伝えること?」
- ・ゆるやかでぃべーと すべての高校生はアルバイトをするべきだ。
- ・【お題】甲子園での思い出の残し方
- ・【お題】動物のキャッチフレーズ
- ・人生で一番思い出に残ってる靴
- ・これ何て呼びますか Part2
- ・スタッフと宿泊客が全員斜め上を行くホテルのレビュー
- ・あなたが好きな本屋さんを教えてください
- ・かっこよく答えてください!!
- ・一回も披露したことのない豆知識
- ・ショボ短歌会
- ・いちばん失敗した人決定戦
- ・性格悪い人が優勝
- ・最速怪談選手権
- ・限定しりとり
- ・性格いい人が優勝
- ・これ何て呼びますか
- ・チョコミントアイス
- ・単二電池
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・ゴリラ向け動画サイト「ウホウホ動画」にありがちなこと
- ・泣きながら食べたご飯の思い出
- ・一番好きなみそ汁の具材は?
- ・人生で一番お金がなかったとき
- ・カラオケの鉄板ソング
- ・自分用のお土産
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
excelに貼り付けた数値が勝手に...
-
エクセルVBAでセルに入力したパ...
-
excel INDIRECT 他ファイル参照
-
Teraマクロで日付ディレクトリ...
-
EXCELのVBAで画像を選んだ順に...
-
Excelでリンクを使用すると#N/A...
-
VLOOKUP関数とネットワークに置...
-
ミュージックファイルのファイ...
-
ローマ字→カタカナへ変換(エク...
-
マクロ 実行ボタンを押さずに...
-
EXCELのセルへ、デジタル時計を...
-
コマンドボタンを押すたびに大...
-
Excel VBA のdebug(F8キー) が...
-
Excel:コマンドボタンの移動
-
Excelを開いた時に表示さ...
-
エクセルのマクロ機能で前のシ...
-
エクセル グラフの軸の最小値最...
-
押したボタンの位置取得(共通の...
-
スクロールしてもボタンを常に...
-
エラーになってないのにVBA...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルVBAでセルに入力したパ...
-
excelに貼り付けた数値が勝手に...
-
EXCELのVBAで画像を選んだ順に...
-
Teraマクロで日付ディレクトリ...
-
ファイルを並び替えるときの「...
-
ハイパーリンクで前回値をひき...
-
VBAでFileDialogを利用してファ...
-
エディタで効率的な切り出し方法
-
PDF ファイルが開けません。
-
Excel VBAで自動的にハイパーリ...
-
Excelでリンクを使用すると#N/A...
-
EXCELのマクロを使って、テキス...
-
excel INDIRECT 他ファイル参照
-
初めまして、VBA初心者です。 ...
-
「やよいの青色申告」のファイ...
-
VLOOKUP関数とネットワークに置...
-
エクセルVBAで複数のファイ...
-
=CELL("filename")で取得したフ...
-
CSVで文字化けしてしまうのを直...
-
EXCEL VBA ー 同一フォルダ内の...
おすすめ情報