
No.7ベストアンサー
- 回答日時:
こんにちは。
Wendy02 です。>今はツール→マクロ→マクロという手順で行うしか
>私の知識不足でできません。
ツールバーを右クリックして、[コントロールツール]を出し、その中から、コマンドボタンを選んで、シートに貼り付けます。
そのボタンを右クリックすると、
コードの表示というのがあります。それをクリックします。
そうすると、Visual Basic Editor画面が現れその中には、以下のように出ているかと思います。
Private Sub CommandButton1_Click()
End Sub
そこで、その間に以下のように書き加えます。
(ただし、マクロ名は、FindFileName が、「標準モジュール」に登録されていることが条件です。)
↓
Private Sub CommandButton1_Click()
Call FindFileName '一行書き加えます。
End Sub
なお、ツール-マクロ-マクロという代わりに、Altを押しながら、F8 を押すとマクロ名の一覧が出ます。
No.6
- 回答日時:
再度のこんにちは。
No.3です。既にWendy02さんがフォローしてくださってますが、
開きたいファイル名が、例えば、"売上.xls"
それが、セルA1に入力されているとした場合
先のコードでは、セルA1には、"売上.xls"と拡張子(.xls)込みで入力されているものとしています。
もし、拡張子なしで、"売上" とだけ入力されているのであれば、
下記のように●のところに拡張子(.xls)を付加しましょう。
---------------------------------------------
Private Sub CommandButton1_Click()
Dim Wbk As Workbook
Dim Fname As String
Fname = Range("A1").Value & ".xls" '●ここ
For Each Wbk In Workbooks
If Wbk.Name = Fname Then
MsgBox Fname & "は既にオープンされています"
Exit Sub
End If
Next Wbk
If Dir(Fname) = "" Then
MsgBox Fname & "はありません"
Else
Workbooks.Open Fname
End If
End Sub
-----------------------------------------
以上です。
No.5
- 回答日時:
こんにちは。
>シート内にある顧客マスターを電話番号やふりがなの一部から検索し、あるセルに表示させ、そのセル内の名前と同じブックを開かせたいのです。
これは、具体的なセル情報がないと、編集していただかなくてはなりません。また、ふりがな情報はセル上に出されているものとします。それは、書かれていないので、こちらかで作ったものをサンプルとさせていただきます。
なお、#3 のtaocat さんに関するものは、
>、「***はありません」となってしまいます。***は確かに同フォルダ内にあるのですが・・・。何か私のやり方が悪いんでしょうか?
これは、たぶん、セル上のリストにあるファイル名(Fname)に、.xls の拡張子がついていないからだと思います。
以下は、こちらで考えたサンプルです。
A B C D E
1 名前 ふりがな 住所 電話番号 ファイル名
2 朝日 アサヒ 東京 12-124 050821a
3 毎日 マイニチ 大阪 12-125 050822a
'<標準モジュール登録>
Option Explicit
Sub FindFileName()
Dim myFind As String, myFadd As String, rtn As Integer
Dim DataRng As Range
Dim c As Range
Set DataRng = Range("A1").CurrentRegion 'リストのある左端上を設定
myFind = Application.InputBox("検索値を入力してください。", Type:=2)
If myFind = "False" Or myFind = "" Then Exit Sub
Set c = DataRng.Find(What:=myFind, LookIn:=xlValues, LookAt:=xlPart)
If Not c Is Nothing Then
myFadd = c.Address
Do
rtn = MsgBox(DataRng.Cells(c.Row, 1) & "でよろしいですか?", _
vbYesNoCancel)
If rtn = vbYes Then
Call OpenFile(DataRng.Cells(c.Row, 5))
Exit Sub
ElseIf rtn = vbCancel Then
Exit Sub
End If
Set c = DataRng.FindNext(c)
Loop Until c Is Nothing Or c.Address = myFadd
End If
End Sub
Private Sub OpenFile(Fname As String)
Dim myFno As Integer
If InStr(Fname, ".xls") = 0 Then
Fname = Fname & ".xls"
End If
If Dir(Fname) <> "" Then
myFno = FreeFile
On Error Resume Next
Open Fname For Binary Lock Read Write As #myFno
Close #myFno
If Err.Number = 0 Then
Workbooks.Open Fname
ElseIf Err.Number = 70 Then
MsgBox Fname & "は開いています。", 64
Err.Clear
End If
Else
MsgBox Fname & "は存在しません。", 16
End If
End Sub
ほぼ私のやりたかったことができました。感激です。本当にありがとうございました。ついでにもう一つお聞きしたいのですが、このマクロをコマンドボタンから呼び出すのはできますか?今はツール→マクロ→マクロという手順で行うしか私の知識不足でできません。よろしくお願いします。
No.4
- 回答日時:
こんにちは。
>文字と同じ名前のファイル
がエクセルブックとは限らないかもしれないので、
Private Sub CommandButton1_Click()
Dim sPath As String
sPath = ThisWorkbook.Path & "\" & Range("A1").Value
If Dir(sPath) <> "" Then
With CreateObject("WScript.Shell")
.Run """" & sPath & """"
End With
End If
End Sub
としてみました。
(A1セルには、開きたいファイルの「ファイル名.拡張子」があるとします。)
関連付けされたファイルなら全て開きます。
ブックの場合、既に開いていたときはアクティブになります。
ありがとうございます。お礼が遅くなってごめんなさい。今回はエクセルブックのみですが、そうではない時の参考になりました。みなさん凄いですね。
No.3
- 回答日時:
こんばんは。
該当ブックが既にオープンされてる場合のチェックも入れたほうがベターですね。
-------------------------------------------------
Private Sub CommandButton1_Click()
Dim Wbk As Workbook
Dim Fname As String
Fname = Range("A1").Value
For Each Wbk In Workbooks
If Wbk.Name = Fname Then
MsgBox Fname & "は既にオープンされています"
Exit Sub
End If
Next Wbk
If Dir(Fname) = "" Then
MsgBox Fname & "はありません"
Else
Workbooks.Open Fname
End If
End Sub
-------------------------------------------
以上です。
ありがとうございます。お礼が遅くなってごめんなさい。教えていただいたようにしたのですが、「***はありません」となってしまいます。***は確かに同フォルダ内にあるのですが・・・。何か私のやり方が悪いんでしょうか?
No.2
- 回答日時:
こんばんは。
>VLOOKUPなどで検索し、
この部分の意味がわかりませんが、こういうことでしょうか?
一応、カレントディレクトリのファイル名を検索して、その名前があれば、ブックを開くようにしています。
Private Sub CommandButton1_Click()
Dim Fname As String
Fname = Range("A1").Value
If Dir(Fname) <> "" Then
Workbooks.Open Fname
End If
End Sub
この回答への補足
ありがとうございます、説明不足ですみません。私がしたいのはこんなことです。シート内にある顧客マスターを電話番号やふりがなの一部から検索し、あるセルに表示させ、そのセル内の名前と同じブックを開かせたいのです。他に良さそうなやりかたがございましたらご教授下さい。
補足日時:2005/08/26 11:13お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) フォルダ内のエクセルファイルを開かずにデータ採取する関数式 2 2022/12/22 22:15
- Visual Basic(VBA) vbaサブフォルダーをワイルドカードで取得したい 2 2022/11/15 08:04
- Excel(エクセル) 【Excel】指定のセル内容を基に別シートのセルを検索して選択する【VBA】 1 2022/06/16 16:16
- Visual Basic(VBA) VBA初心者です。電話番号の数字の前に0を表示させたいです。 2 2022/12/14 03:58
- Visual Basic(VBA) エクセル VBA 条件によるセル点滅 お詳しい方 ご教授をお願いします。 Excelファイルにて 現 1 2022/11/03 15:53
- その他(データベース) Accessフォームからパラメーターで表示したレコードを指定のExcelのセルへ転送する方法について 2 2022/08/22 18:04
- その他(データベース) Excel VBA 転記について 1 2022/04/20 16:55
- Excel(エクセル) エクセルVBA、ファイル名をセルの値で保存の方法を教えてください。 おそれいります。こちらで数々のエ 6 2023/06/30 22:17
- Excel(エクセル) Excel VBAどこが間違ってますか? 4 2023/07/17 10:04
- Excel(エクセル) エクセルで”入力シート”の文字書式の変更を”出力シート”で同じ文字書式で印刷したいです。VBA希望 4 2023/04/24 11:07
このQ&Aを見た人はこんなQ&Aも見ています
-
好きな人を振り向かせるためにしたこと
大好きな人と会話のきっかけを少しでも作りたい、意識してもらいたい…! 振り向かせるためにどんなことをしたことがありますか?
-
初めて自分の家と他人の家が違う、と意識した時
子供の頃、友達の家に行くと「なんか自分の家と匂いが違うな?」って思いませんでしたか?
-
もし10億円当たったら何に使いますか?
みなさんの10億円プランが知りたいです!
-
あなたなりのストレス発散方法を教えてください!
自分なりのストレス発散方法はありますか?
-
思い出すきっかけは 音楽?におい?景色?
記憶をふと思い出すきっかけは 音楽、におい、景色 どれですか?
-
エクセルVBAでセルに入力したパスでブックを開く
Excel(エクセル)
-
Excel VBA セルと同じ名前のブックを呼び出し、呼び出したシートをコピーする方法について こん
Excel(エクセル)
-
VBAでセル値からフォルダ名を取得するコードについて
Excel(エクセル)
-
-
4
セルの値と同じ名前のシートをアクティブにするには?
Excel(エクセル)
-
5
VBAからファイルをセル入力から開く方法
Excel(エクセル)
-
6
VBAでファイルを開くときにファイル名でワイルドカードを使用したいです
その他(プログラミング・Web制作)
-
7
セルに入力されたパスでフォルダーを開く
Excel(エクセル)
-
8
excel VBA 特定の文字列を含むフォルダを開く方法
Excel(エクセル)
-
9
Excel VBAで同じフォルダ内のファイルを開くには?
Excel(エクセル)
-
10
EXCEL VBA 指定したファイルが存在しない場合メッセージボックスを表示させる
Access(アクセス)
-
11
【Excel VBA】ファイル名が一定でないファイルの指定方法
Excel(エクセル)
-
12
VBAでワークブックの名前を変数にして開かせる?
Excel(エクセル)
-
13
EXCEL VBA セルに既に入力されている文字に文字を追加する
Excel(エクセル)
-
14
エクセルのVBAで日付を検索し転機したい
Visual Basic(VBA)
-
15
サブフォルダから部分一致のエクセルファイルを検索、選択して開くマクロについて
Excel(エクセル)
-
16
エクセルVBAで、条件に一致するセルへ移動
Excel(エクセル)
-
17
VBAでの結合セルのコピー&ペースト
Excel(エクセル)
-
18
エクセルで「特定の文字を含むファイルへのリンク」or「特定の文字を含むファイルの検索の実行」
Excel(エクセル)
-
19
エクセル関数>参照ファイル名をセルから呼び出す
Excel(エクセル)
-
20
エクセルVBAで、PDFファイルを開きたい
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・一番好きなみそ汁の具材は?
- ・泣きながら食べたご飯の思い出
- ・「これはヤバかったな」という遅刻エピソード
- ・初めて自分の家と他人の家が違う、と意識した時
- ・いちばん失敗した人決定戦
- ・思い出すきっかけは 音楽?におい?景色?
- ・あなたなりのストレス発散方法を教えてください!
- ・もし10億円当たったら何に使いますか?
- ・何回やってもうまくいかないことは?
- ・今年はじめたいことは?
- ・あなたの人生で一番ピンチに陥った瞬間は?
- ・初めて見た映画を教えてください!
- ・今の日本に期待することはなんですか?
- ・集中するためにやっていること
- ・テレビやラジオに出たことがある人、いますか?
- ・【お題】斜め上を行くスキー場にありがちなこと
- ・人生でいちばんスベッた瞬間
- ・コーピングについて教えてください
- ・あなたの「プチ贅沢」はなんですか?
- ・コンビニでおにぎりを買うときのスタメンはどの具?
- ・おすすめの美術館・博物館、教えてください!
- ・【お題】大変な警告
- ・洋服何着持ってますか?
- ・みんなの【マイ・ベスト積読2024】を教えてください。
- ・「これいらなくない?」という慣習、教えてください
- ・今から楽しみな予定はありますか?
- ・AIツールの活用方法を教えて
- ・最強の防寒、あったか術を教えてください!
- ・歳とったな〜〜と思ったことは?
- ・モテ期を経験した方いらっしゃいますか?
- ・好きな人を振り向かせるためにしたこと
- ・スマホに会話を聞かれているな!?と思ったことありますか?
- ・それもChatGPT!?と驚いた使用方法を教えてください
- ・見学に行くとしたら【天国】と【地獄】どっち?
- ・これまでで一番「情けなかったとき」はいつですか?
- ・この人頭いいなと思ったエピソード
- ・あなたの「必」の書き順を教えてください
- ・14歳の自分に衝撃の事実を告げてください
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
EXCELで特定のセルに表示...
-
Excel内での検索結果をシート...
-
クリックすると文章が表示され...
-
エクセル 数字をすべて○などの...
-
フォントの色を指定して削除出...
-
Excelで、図形内の文字をセルに...
-
マクロを実行すると画像がズレ...
-
エクセルでPDFリンクを大量...
-
エクセル 未入力セルがあると...
-
太字に設定されているセルの個...
-
Excelでセルをクリックす...
-
現在のセルの位置を返す関数は...
-
Excel:セルの値(文字列)を数...
-
【EXCEL】先週の月曜日の日付を...
-
セルがクリックされた回数をカ...
-
シート保護とグループ化機能を...
-
Excel2007 色のカウント (VBA)
-
Excel ハイパーリンクのURLを別...
-
アポストロフィーの一括挿入 ...
-
エクセル マクロ 相対パスか...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
EXCELで特定のセルに表示...
-
Excel内での検索結果をシート...
-
エクセル 数字をすべて○などの...
-
クリックすると文章が表示され...
-
Excelで、図形内の文字をセルに...
-
太字に設定されているセルの個...
-
Excel ハイパーリンクのURLを別...
-
Excelでセルをクリックす...
-
Excel:セルの値(文字列)を数...
-
現在のセルの位置を返す関数は...
-
フォントの色を指定して削除出...
-
マクロを実行すると画像がズレ...
-
アポストロフィーの一括挿入 ...
-
エクセル 未入力セルがあると...
-
【EXCEL】先週の月曜日の日付を...
-
エクセルでPDFリンクを大量...
-
エクセルでセルをダブルクリッ...
-
EXCELのセルや文字色の反映
-
セルの内容をテキストボックス...
-
セルがクリックされた回数をカ...
おすすめ情報