No.4ベストアンサー
- 回答日時:
FileSystemObjectを使ったらどうですか?
拡張子&ファイル名を取得する方法を書いときます
参照設定で「Microsoft Scripting Runtime」を参照します。
'拡張子のみ取得
Function hoge1(strPath As String) As String
Dim fso As New FileSystemObject
hoge1=fso.GetExtensionName(strPath)
End Sub
'ファイル名のみ取得
Function hoge2(strPath As String) As String
Dim fso As New FileSystemObject
hoge2=fso.GetFileName(strPath)
End Sub
じゃ、そゆことで。
ありがとうございます
そうか、FileSystemObjectか・・・
存在を忘れていました(笑)
参考になりました。早速使わせていただきますw
No.3
- 回答日時:
お疲れ様です。
ファイル名の後ろから"."を探せばいいのではないでしょうか。
(例
Dim ファイル名 As String
Dim 名前 As String
Dim 拡張子 As String
Dim 位置 As Long
ファイル名 = "AIUEO.TXT"
位置 = InStrRev(ファイル名, ".") '// 後ろから文字を検索
名前 = Left$(ファイル名, 位置 - 1) '// 名前が入る
拡張子 = Right$(ファイル名, Len(ファイル名) - 位置) '// 拡張子が入る
(結果
名前 = "AIUEO"
拡張子 = "TXT"
間違っていたらごめんなさい。
おはようございます
お礼が遅くなって申し訳ありません!
InStrRevっていう関数があるんですねw
知らなかったな~^^
私はLen関数で文字列長を取得してから、Loopで回してました(笑)
勉強になりました!
No.2
- 回答日時:
拡張子を認識するためのAPI関数があります。
ファイルのフルパスでもOK
'拡張子のピリオドを<<vbNullChar>>に変換するAPI関数
Private Declare Sub PathRemoveExtension Lib "shlwapi.dll" Alias "PathRemoveExtensionA" (ByVal pszPath As String)
Sub Main()
Const FILE1 As String = "c:\test\index.html"
Const FILE2 As String = "c:\test\index.html.doc.txt.wav"
Const FILE3 As String = "index"
Const FILE4 As String = "index.html.doc.txt.wav.ウィルス"
Dim wkStr1 As String
Dim wkStr2 As String
Call GetGetGet(FILE1, wkStr1, wkStr2)
MsgBox _
"ファイル名:[" & FILE1 & "]" & vbNewLine & _
"ファイル :[" & wkStr1 & "]" & vbNewLine & _
"拡張子 :[" & wkStr2 & "]"
Call GetGetGet(FILE2, wkStr1, wkStr2)
MsgBox _
"ファイル名:[" & FILE2 & "]" & vbNewLine & _
"ファイル :[" & wkStr1 & "]" & vbNewLine & _
"拡張子 :[" & wkStr2 & "]"
Call GetGetGet(FILE3, wkStr1, wkStr2)
MsgBox _
"ファイル名:[" & FILE3 & "]" & vbNewLine & _
"ファイル :[" & wkStr1 & "]" & vbNewLine & _
"拡張子 :[" & wkStr2 & "]"
Call GetGetGet(FILE4, wkStr1, wkStr2)
MsgBox _
"ファイル名:[" & FILE4 & "]" & vbNewLine & _
"ファイル :[" & wkStr1 & "]" & vbNewLine & _
"拡張子 :[" & wkStr2 & "]"
Exit Sub
End Sub
Function GetGetGet(ByVal inFileName As String, ByRef outFileName As String, ByRef outKakutyousi As String)
Dim valWork As Variant
'戻りパラメータ初期化
outFileName = ""
outKakutyousi = ""
'拡張子を<<vbNullChar>>に変換
Call PathRemoveExtension(inFileName)
'vbNullCharで切り分ける
valWork = Split(inFileName, vbNullChar)
'配列の先頭がファイル名
outFileName = valWork(0)
'拡張子が存在してない時は、以下を通らない
If UBound(valWork) > 0 Then
outKakutyousi = valWork(1)
End If
End Function
御有難う御座りまスル!!
ムムム・・・・・・・・
何か非常に難しいですな
拙者の存ぜぬ関数なる物が
多分に表記されておる為か
理解に時が必要じゃw
拙者の現在の習熟能力では
把握出来ぬ故、暫しの時を
くだされ、勉学に勤しんで
みるとしよう・・・(笑)
VBって奥が深いですね!
まだまだ勉強が必要です。
皆さんホントにどうもです
o(o|o)/ (V)o\o(V)
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・「みんな教えて! 選手権!!」開催のお知らせ
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~1/20】 追い込まれた犯人が咄嗟に言った一言とは?
- ・洋服何着持ってますか?
- ・みんなの【マイ・ベスト積読2024】を教えてください。
- ・「これいらなくない?」という慣習、教えてください
- ・今から楽しみな予定はありますか?
- ・AIツールの活用方法を教えて
- ・【選手権お題その3】この画像で一言【大喜利】
- ・【お題】逆襲の桃太郎
- ・自分独自の健康法はある?
- ・最強の防寒、あったか術を教えてください!
- ・【大喜利】【投稿~1/9】 忍者がやってるYouTubeが炎上してしまった理由
- ・歳とったな〜〜と思ったことは?
- ・ちょっと先の未来クイズ第6問
- ・モテ期を経験した方いらっしゃいますか?
- ・好きな人を振り向かせるためにしたこと
- ・【選手権お題その2】この漫画の2コマ目を考えてください
- ・【選手権お題その1】これってもしかして自分だけかもしれないな…と思うあるあるを教えてください
- ・スマホに会話を聞かれているな!?と思ったことありますか?
- ・それもChatGPT!?と驚いた使用方法を教えてください
- ・見学に行くとしたら【天国】と【地獄】どっち?
- ・これまでで一番「情けなかったとき」はいつですか?
- ・この人頭いいなと思ったエピソード
- ・あなたの「必」の書き順を教えてください
- ・14歳の自分に衝撃の事実を告げてください
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
コマンドプロンプトの「%1」と...
-
ftp処理でmove(移動)を行いたい
-
ファイル名に ” を使うと エク...
-
コマンドプロンプトでファイル...
-
コマンドプロンプトで変数が数...
-
【バッチファイル】forコマンド...
-
フォルダ内の更新日時が一番新...
-
ファイル名を一括してリネーム...
-
Excel VBA マクロ ファイル名ソ...
-
[DOS] コピー先に同じファイル...
-
バッチファイルでファイルを置換
-
ExifToolでの文字化け対策
-
バッチファイルで、iniファイル...
-
テキストファイルのファイル名...
-
ファイル名を該当フォルダ内か...
-
サブフォルダからファイルをコ...
-
バッチ処理で16進数でファイル...
-
バッチコマンドでファイル名の...
-
Windowsコマンドプロンプトで、...
-
前日日付のファイルGETバッチ
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
コマンドプロンプトの「%1」と...
-
ftp処理でmove(移動)を行いたい
-
コマンドプロンプトでファイル...
-
フォルダ内の更新日時が一番新...
-
[DOS] コピー先に同じファイル...
-
コマンドプロンプトで変数が数...
-
バッチファイルで、iniファイル...
-
ExcelVBAのDirでスペース含むフ...
-
ファイル名に ” を使うと エク...
-
バッチコマンドでファイル名の...
-
サブフォルダからファイルをコ...
-
DOSのバッチ作成について‐FORの...
-
ファイル名の頭5桁と同名のフォ...
-
.batでファイル名から抽出して...
-
VBA GetAttrについて教えてくだ...
-
aタグのhrefにネットワークパス...
-
バッチにて複数のcsvファイルを...
-
【vbs】ファイル名の検索と該当...
-
ファイル名を該当フォルダ内か...
-
Windowsコマンドプロンプトで、...
おすすめ情報