Windows7、EXCEL2013を使用しています。
VBAを使い、任意のフォルダを指定し、その中にあるファイル名を
・拡張子ありで取得するコマンドボタン(オブジェクト名:output)
・拡張子なしで取得するコマンドボタン(オブジェクト名:output_n)
の2パターンで取得するものをつくりたいと考えています。
拡張子ありのほうは、以下のように作成しました。
-----------------------------------------------------------
Private Sub output_Click()
Dim Target As String
Dim Extraction As Variant
Dim buf As String
Dim i As Long
'入力欄の値を取得
Target = Target_i.Value
'ファイル名取得
If Target = "" Then
MsgBox "パスを入力してください"
Exit Sub
End If
buf = Dir(Target & "*.*")
Do While buf <> ""
i = i + 1
Cells(i, 1) = buf
buf = Dir()
Loop
MsgBox i & "件ありました。"
End Sub
-----------------------------------------------------------
拡張子ありのこのコードは問題なく動作しています。
これを応用して拡張子なしに対応したものを作成したいのですが、
以下のようなコードにしたところ、エラーとなりました。
-----------------------------------------------------------
Private Sub output_n_Click()
Dim Target As String
Dim buf As String
Dim i As Long
Dim FileName As Object
Dim sFilename As String
Dim Findpoint As Long
Dim strLen As Long
'入力欄の値を取得
Target = Target_i.Value
'空白かチェック
If Target = "" Then
MsgBox "パスを入力してください"
Exit Sub
End If
'ファイル名取得
buf = Dir(Target & "*.*")
'拡張子をとる
sFilename = buf.getbasename(sFilename) ←ここのbufが黄色で反転
Do While strPath <> ""
i = i + 1
Cells(i, 1) = strPath
strPath = Dir()
Loop
MsgBox i & "件ありました。"
End Sub
-----------------------------------------------------------
エラー内容は、
【コンパイルエラー:装飾子が不正です。】です。
一度ファイル名を取得し、拡張子をとった値を返したいのですが、
取得したファイル名(buf)から拡張子をとるにはどうすればよいでしょうか。
にわかの私にはこれ以上がわかりません。
どなたか教えてください。
宜しくお願いします。
No.2ベストアンサー
- 回答日時:
こんにちは。
ふつう、このような場合は、FileSystemObject (objFS) ではなく、InstrRev で、後ろから、コンマを探して、切り捨てます。
例:
Fn = "Test1.xlsx"
i = InStrRev(Fn, ".")
Debug.Print Left(Fn, i - 1)
なぜ、FileSystemObjectを使わないかというと、オブジェクトを呼びこむ時の時間、つまりオーバーヘッドが掛かるからです。今回は、ご質問者様の内容をそのまま活かしました。
'//
Private Sub output_n_Click()
Dim Target As String
Dim Target_i As Range
Dim objFS As Object 'FileSystemObject
Dim buf As String
Dim i As Long
Dim FileName As Object
Dim strPath As String
Dim Findpoint As Long
Dim strLen As Long
Set objFS = CreateObject("Scripting.FilesystemObject")
'入力欄の値を取得
Set Target_i = ActiveCell '←※臨時で置きました。
Target = Target_i.Value
'空白かチェック
If Target = "" Then
MsgBox "パスを入力してください"
Exit Sub
End If
'ファイル名取得
buf = Dir(Target & "*.*")
'拡張子をとる
Do
i = i + 1
strPath = objFS.GetBaseName(buf) 'ループの中に入れました。
Cells(i, 1).Value = strPath
buf = Dir()
Loop While buf <> "" '判定はbuf でします。
MsgBox i & "件ありました。"
End Sub
'//
ご回答ありがとうございます。
アドバイスに基づき、下記のように変更したところ、ファイル名を取得できました。
(一部抜粋)
Do While buf <> ""
i = i + 1
k = InStrRev(buf, ".") 'カンマの位置を特定
out = Left(buf, k - 1) 'カンマから左を返す
Cells(i, 1) = out
buf = Dir()
Loop
オーバーヘッドのことなど、考慮できていない点がありました。
具体的なサンプルを提示していただき、大変助かりました。
やはり継ぎ接ぎのコードでは不具合が出たとき対応できないことがわかりました・・・
今後は理解に重点をおき、もう少し勉強します。
2名の方、ありがとうございました。
No.3
- 回答日時:
失礼しました。
以下の場合などではコンパイルエラーにはなりませんね。1・VBE でツール→オプション→変数の宣言を強制する のチェックが外れている場合。
ただし、実行すると、実行時エラー424 で止まるハズ?
2・Target_i をどこか別の所でオブジェクト型でパブリック変数とし、セットしている場合
まだ有るかもしれませんが取りあえず思いついたのはこのケースです。
私の拙い説明で、深いところまで察して頂き誠にありがとうございます。
Target_iは別のところで変数としてセットしていました。
また困ったことがありましたら質問をすることもあると思いますが、
その時はどうぞよろしくお願いします。
ありがとうございました。
No.1
- 回答日時:
あなたが問題なく動くという
Private Sub output_Click() でも
>Target = Target_i.Value
↑ここでコンパイルエラーになるハズなんですけどね?
GetBaseName はFileSystemobject から利用することになります。
http://officetanaka.net/excel/vba/filesystemobje …
貴方のようにテキトーに繋げてもエラーになるだけです。
>貴方のようにテキトーに繋げてもエラーになるだけです。
返す言葉もございません・・・
きちんと理解できるよう、勉強します。
コンパイルエラーになるはずのところで、問題なく動いていた理由は
不明ですが・・・
ありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) フォルダ内のワードファイルをPDFに一括変換するVBA 3 2023/06/09 16:51
- Visual Basic(VBA) フォルダの場所を可変にしたいです(マクロ) 4 2023/05/11 10:00
- Visual Basic(VBA) 複数csvを横に追加していくマクロについて 2 2023/04/25 09:19
- Visual Basic(VBA) Excel-VBAでのファイルの開き方 4 2023/02/14 11:01
- Visual Basic(VBA) VBAのユーザーフォームのテキストボックスに入力制限をしたい 6 2022/11/15 08:28
- Excel(エクセル) Excel VBAどこが間違ってますか? 4 2023/07/17 10:04
- Excel(エクセル) エクセル VBA For Next 繰り返しの書き方を教えてください 6 2022/09/01 14:11
- Visual Basic(VBA) 複数のcsvファイルをExcelに一括変換したい 2 2023/03/03 12:44
- Excel(エクセル) Excelにて、フォルダ内のTextファイルをマクロで統合すると文字化けしてしまう時の解消コード 4 2023/01/01 07:32
- Visual Basic(VBA) オブジェクトが見つかりません 1 2023/06/24 19:43
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~11/12】 急に朝起こしてきた母親に言われた一言とは?
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・好きな「お肉」は?
- ・あなたは何にトキメキますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・チョコミントアイス
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・あなたの習慣について教えてください!!
- ・ハマっている「お菓子」を教えて!
- ・高校三年生の合唱祭で何を歌いましたか?
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・家の中でのこだわりスペースはどこですか?
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・架空の映画のネタバレレビュー
- ・「お昼の放送」の思い出
- ・昨日見た夢を教えて下さい
- ・ちょっと先の未来クイズ第4問
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・メモのコツを教えてください!
- ・CDの保有枚数を教えてください
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
首吊りどこ締めるの
-
2つの数値のうち、数値が小さい...
-
EXCELで式からグラフを描くには?
-
エクセルで数式の答えを数値と...
-
エクセル指定した範囲からラン...
-
彼女のことが好きすぎて彼女の...
-
白血球が多いとどんな心配があ...
-
EXCELで条件付き書式で空白セル...
-
勃起する時って痛いんですか? ...
-
小数点以下を繰り上げたものを...
-
VLOOKUP関数を使用時、検索する...
-
リンク先のファイルを開かなく...
-
一番多く表示のある値(文字列...
-
検便についてです。 便は取れた...
-
Excelで""で囲む方法
-
精液の落とし方を教えてください
-
エクセルのラベルの値(文字列...
-
ある範囲のセルから任意の値を...
-
「内数」という言葉の意味がよ...
-
MIN関数で空白セルを無視したい...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
首吊りどこ締めるの
-
彼女のことが好きすぎて彼女の...
-
白血球が多いとどんな心配があ...
-
検便についてです。 便は取れた...
-
精液の落とし方を教えてください
-
勃起する時って痛いんですか? ...
-
2つの数値のうち、数値が小さい...
-
エクセル指定した範囲からラン...
-
エクセルで数式の答えを数値と...
-
これって喉仏ですか? 私は女性...
-
小数点以下を繰り上げたものを...
-
EXCELで条件付き書式で空白セル...
-
EXCELで式からグラフを描くには?
-
イタリアから帰国する際、肉製...
-
エクセルのラベルの値(文字列...
-
Excel 0目標に対して数字があ...
-
ある範囲のセルから任意の値を...
-
風俗店へ行く前のご飯
-
リンク先のファイルを開かなく...
-
甲状腺が腫れているが血液検査...
おすすめ情報