
仕事で使うファイルの整理が苦手で、フォルダーを用途別にしたまでは
よいのですが、どこに置いたか忘れて結局ファイル名の検索などで
目的のファイルにたどりついたりしています。
「効率よく作業したい」これが第一なのですが
「私はこうしている」と同僚に自慢したい面もあり
下記のようなことが出来ないかと考えました。
(1)Excel VBA でファイル一覧を作成する。
(2)ファイル名を格納したセル(あるいは行)をクリックすると
目的のファイルが開く。
(1)は出来ました。
(2)はOffice系だけでなくPDF・JPEG・CSV等がありつまづいています。
(1)もサンプルVBAを使ってどうにか作れた程度の初心者です。
(2)はVBA初心者レベルで何とかなるものでしょうか。
OS:VISTA Office2007です。
No.2ベストアンサー
- 回答日時:
こんにちは。
拡張子が正しく設定されているなら、こういうコードで開くはずです。
ダブルクリックして開きます。ハイパーリンクは必要ありません。ファイル名は、フル・ファイル名であっても、単に、ファイル名だけでも開くようにしてあります。ファイル名だけの時は、デフォルト・パスに入っていないと開かないようになっています。
Private Sub Worksheet_BeforeDoubleClick(ByVal Target As Range, Cancel As Boolean)
'Win 2000以上
Dim Fname As String
Cancel = True
'デフォルト・パス(ユーザー設定)
Const mPATH As String = "C:\MyFiles\" '*要設定
If Target.Value = "" Then Exit Sub
If Dir(mPATH, vbDirectory) = "" Then MsgBox "Default Path Err!": Exit Sub
If InStr(Target.Value, mPATH) > 0 Then
Fname = Target.Value
Else
Fname = mPATH & Target.Value
End If
If Dir(Fname) <> "" Then
CreateObject("Shell.Application").ShellExecute Fname
Else
MsgBox "ファイルが見当たりません。", vbInformation
End If
End Sub
CreateObject("Shell.Application").ShellExecute Fname
色々な局面で利用できそうです。ありがとうございました。
また、ファイルなしの判定も載せていただき大変参考になりました。
No.1
- 回答日時:
>ファイル名を格納したセル(あるいは行)をクリックすると
>目的のファイルが開く。
下記のコードの内、"D:\hoge\hoge.csv" の部分は、行内の文字列から取得してください。
●その行のどこかに、「目的のファイル」へのハイパーリンクを貼る
ActiveSheet.Hyperlinks.Add Anchor:=Selection, Address:="D:\hoge\hoge.CSV", _
TextToDisplay:="表示名"
●その行を右クリックで、「目的のファイル」を開く
Private Sub Worksheet_BeforeRightClick(ByVal Target As Range, Cancel As Boolean)
Cancel = True
ActiveWorkbook.FollowHyperlink "D:\hoge\hoge.csv"
End Sub
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
動かなくなってしまった古いVBA...
-
vbs ブック共有を解除
-
フォルダ階層・ファイル名・ペ...
-
ファイルを複数選択した時のフ...
-
「エクセルファイルが開いてい...
-
EXCEL VBAを使ったファイル解析...
-
ExcelVBA 文字コード変換
-
「AccessViolationException」...
-
excel マクロ PDF化の際のエラ...
-
エクセルのプロパティーでセキ...
-
エクセルvbaでdocuworksprinter...
-
特定のエクセルファイルが止ま...
-
エクセルのハイパーリンクがコ...
-
カンマ区切りのCSVファイルから...
-
エクセルVBAで一つ上の階層...
-
frxファイルの役目
-
ファイルをコピーできない
-
Wordで差込印刷した後に別々の...
-
[エクセル]コピーするとオブジ...
-
Excel 相対パス
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
動かなくなってしまった古いVBA...
-
「エクセルファイルが開いてい...
-
ffftpでファイル取得が0バイト...
-
サブフォルダ含むフォルダ内の...
-
Long型で表現できないファイル...
-
タイムスタンプの更新の方法2
-
VB6でUTF-8ファイルの読取りを
-
FileDialog オブジェクトでファ...
-
vbs ブック共有を解除
-
vbaサブフォルダーをワイルドカ...
-
AccessからOLEオブジェクト型の...
-
ファイルを複数選択した時のフ...
-
webブラウザからローカルファイ...
-
EXCEL VBAを使ったファイル解析...
-
エクセルのVBAで開いている...
-
VBAでCSVファイルを読み込もう...
-
【ACCESS VBA】アクセスからデ...
-
VBAでのファイル名と更新日(作...
-
Wordのプロパティ・総ページ数...
-
「AccessViolationException」...
おすすめ情報