
A 回答 (3件)
- 最新から表示
- 回答順に表示
No.3
- 回答日時:
#2です
返信へのアドバイスです。
>サブフォルダ内にある
とありましたので、FSOを使い、再帰処理でフォルダパス内にあるサブフォルダすべてに対してファイルを探しています。
再帰処理をしない場合は、該当ロジックを削除又は無効にしてください。
又、Dir関数にした方が処理速度が上がります。
vba fso 再帰処理やvba Dirなどでぐーぐる先生に聞いて確認してください。
No.2
- 回答日時:
こんにちは、
①は一覧をクリックして開くと言う事?
②は、ファイル名指定で開くと言う事?
自身でデバッグ、改造が出来るとして、、参考
①
Sub Sample()
Call Filelink("\\012345\ab\c")
End Sub
Sub Filelink(Path As String)
Dim FSO As Object, Folder As Variant, File As Variant
Dim hyplink As Hyperlink
Dim i As Long: i = 1
Set FSO = CreateObject("Scripting.FileSystemObject")
For Each Folder In FSO.GetFolder(Path).SubFolders
Call Filelink(Folder.Path)
Next Folder
For Each File In FSO.GetFolder(Path).Files
Set hyplink = ActiveSheet.Hyperlinks.Add(Anchor:=Cells(i, 1), _
Address:=File.Path, _
TextToDisplay:=File.Name)
i = i + 1
Next File
End Sub
②
Sub Sample1()
Call FileSearchOpen("\\012345\ab\c", Range("C3").Value)
End Sub
Sub FileSearchOpen(Path As String, Target_Name As String)
Dim FSO As Object, Folder As Variant, File As Variant
Set FSO = CreateObject("Scripting.FileSystemObject")
For Each Folder In FSO.GetFolder(Path).SubFolders
Call FileSearchOpen(Folder.Path, Target_Name)
Next Folder
For Each File In FSO.GetFolder(Path).Files
If File.Name = Target_Name Then
CreateObject("Shell.Application").ShellExecute File
' Workbooks.Open File
Exit For
End If
Next File
End Sub
①Sampleを実行
②Sample1を実行
C3セル入力確定時をトリガーにするならシートイベントにしてください。
>選択した.xlsxファイルが開く
Workbooks.Open File でOK
新規ブックで自己責任で検証してください。
ありがとうございます。
検索ファイル数が多すぎるのか、「応答なし」になりながらも
抽出は継続して行われていることを確認しました。
教えていただいたことをベースに調整をかけてみます。
No.1
- 回答日時:
こんにちは
どこまで作れて、何が「想定通りいかない」のかさっぱりわかりませんが・・・
>マクロの作成方法のご教授をお願います。
とのことなので、概略の考え方を。
(きちんと知りたければ、どこでどのように躓いているのかをキチンと説明した方が、適切な回答を得られると思います)
①に関しては、全ての.xlsxファイルをリストアップするようなマクロなら、検索すればいろいろ見つかると思います。
ですので、ほとんどそのまま利用できるのではと思います。
>「任意の文字を含む」
に限定する場合は、Dir関数等を利用してリストアップするケースであれば、検索対象を「*任意の文字列*.xlsx」のようにしておくことで、可能と思われます。
他の方法で行う場合あっても、リストに記入する前に、「任意の文字列を含んでいるか」を文字列チェックをして、該当しない場合は「リストに記入する」処理をスキップするように(=リストに記入しない)すればよいでしょう。
②に関しては、選択されたセルの内容を読み取って、それを開くという方法でもよいでしょうし、ファイル名だけからパスを作成するのは面倒なので、セルのハイパーリンク機能を利用して、①でリストに記入する際に一緒にリンクを設定しておくようにすれば、②に関するマクロは作成する必要が無くなるものと想像します。
ありがとうございます。
質問の仕方が分かりにくく申し訳ありません。
以後また質問する際には、アドバイス頂いたように躓いている点について理解しやすい様にまとめるようにします。
また、ハイパーリンク機能等、他の選択肢もあること勉強になりました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) 【Excel】指定のセル内容を基に別シートのセルを検索して選択する【VBA】 1 2022/06/16 16:16
- Visual Basic(VBA) サブフォルダ(データ)にある複数の.xlsxファイルのSheet3のA2セルの値で01から左側をB2 2 2022/08/14 15:46
- Visual Basic(VBA) エクセルのマクロについて教えてください。 2 2023/06/04 09:39
- Excel(エクセル) マクロでボタンにつける名前がどこに設定されているかわからないケースがありました。 1 2023/06/19 19:37
- Visual Basic(VBA) VBA 参照先で選んだファイルをコピーし、出力先に別名で保存したい 8 2022/05/13 20:37
- Visual Basic(VBA) VBAコードを張り付け後のエクセルの進め方 2 2023/02/07 18:24
- Visual Basic(VBA) 集めたシートのシート名を変更したい。 下記のコードでサブフォルダにあるファイルのSheet3を集めて 6 2022/08/23 10:38
- Visual Basic(VBA) Excelのマクロコードについて教えてください。 1 2022/03/27 13:25
- Visual Basic(VBA) エクセルのマクロについて教えてください。 2 2023/07/06 17:46
- Visual Basic(VBA) 入力ボックスが繰り返しポップアップして止まらない。 下記コードでファイル名の変更をしたいのですが、変 1 2022/09/08 11:27
このQ&Aを見た人はこんなQ&Aも見ています
-
サブフォルダ含むフォルダ内の全ファイルから指定文字列を含んだファイルの情報を一覧出力させたい
Visual Basic(VBA)
-
エクセルVBAでセルに入力したパスでブックを開く
Excel(エクセル)
-
excel VBA 部分一致の名前をパスに指定する方法
Excel(エクセル)
-
-
4
VBAでファイルを開くときにファイル名でワイルドカードを使用したいです
その他(プログラミング・Web制作)
-
5
部分検索でフォルダ名を検索するマクロ
Excel(エクセル)
-
6
VBA フォルダ名に特定の文字を含むフォルダを別フォルダにコピーするコードを教えて下さい
Visual Basic(VBA)
-
7
vbaサブフォルダーをワイルドカードで取得したい
Visual Basic(VBA)
-
8
excel VBA 特定の文字列を含むフォルダを開く方法
Excel(エクセル)
-
9
ExcelVBAでBookを開く時にファイル名の一部だけを指定で
Access(アクセス)
-
10
VBAでセル値からフォルダ名を取得するコードについて
Excel(エクセル)
-
11
VBAで保存しないで閉じると空のBookが残る
Excel(エクセル)
-
12
VBA 最新のフォルダ取得
Excel(エクセル)
-
13
エクセルVBAで5行目からオートフィルタモードに設定したいたい
Excel(エクセル)
-
14
エクセルVBAのエディターが上書きモード?に・・・・。
Excel(エクセル)
-
15
エクセルで「特定の文字を含むファイルへのリンク」or「特定の文字を含むファイルの検索の実行」
Excel(エクセル)
-
16
VBA(エクセル)で自動的にボタンをクリックさせるには
その他(プログラミング・Web制作)
-
17
EXCEL VBA 指定したファイルが存在しない場合メッセージボックスを表示させる
Access(アクセス)
-
18
EXCEL VBA セルに既に入力されている文字に文字を追加する
Excel(エクセル)
-
19
エクセルマクロで不特定なファイル名を使用するには
Excel(エクセル)
-
20
VBA、ファイル名検索から開く、部分一致
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルのプロパティーでセキ...
-
ファイルのアクセス回数について
-
ExcelブックをGoogleスプレッド...
-
Wordで差込印刷した後に別々の...
-
エクセル UserForm 呼び出しで...
-
Excel csv保存 列数が異なる場...
-
【Excel VBA】ファイルを保存し...
-
PowerPoint 2002でファイル名を...
-
EXCEL 検索時の設定
-
マクロ実行後、表示がおかしくなる
-
エクセルのマクロで行と列の削...
-
実行時エラー52
-
複数のexcelのファイルを一括で...
-
エクセルファイル名に更新日時...
-
Word文書:頁数カウント
-
エクセル2003で複数開いたウィ...
-
エクセルで複数のコメントのサ...
-
エクセルvbaでdocuworksprinter...
-
カンマ区切りのCSVファイルから...
-
ファイルサーバ上のファイルが...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルのプロパティーでセキ...
-
ファイルのアクセス回数について
-
ExcelブックをGoogleスプレッド...
-
Wordで差込印刷した後に別々の...
-
Excel csv保存 列数が異なる場...
-
マクロ実行後、表示がおかしくなる
-
エクセル UserForm 呼び出しで...
-
PowerPoint 2002でファイル名を...
-
エクセルファイル名に更新日時...
-
エクセルでcsvファイルを開いて...
-
複数のexcelのファイルを一括で...
-
サブフォルダから部分一致のエ...
-
大量のCSVファイルをExcel形式...
-
EXCEL 検索時の設定
-
実行時エラー52
-
vbaでボタンをクリックして上書...
-
【Excel VBA】ファイルを保存し...
-
エクセルのマクロで行と列の削...
-
アクセスからエクセルのプロシ...
-
【マクロ】webアドレスにて指定...
おすすめ情報